run-elasticsearch-locally.asciidoc 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  1. [[run-elasticsearch-locally]]
  2. == Run {es} locally in Docker (without security)
  3. ++++
  4. <titleabbrev>Local dev setup (Docker)</titleabbrev>
  5. ++++
  6. [WARNING]
  7. ====
  8. *DO NOT USE THESE INSTRUCTIONS FOR PRODUCTION DEPLOYMENTS*
  9. The instructions on this page are for *local development only*. Do not use these instructions for production deployments, because they are not secure.
  10. While this approach is convenient for experimenting and learning, you should never run the service in this way in a production environment.
  11. ====
  12. The following commands help you very quickly spin up a single-node {es} cluster, together with {kib} in Docker.
  13. Note that if you don't need the {kib} UI, you can skip those instructions.
  14. [discrete]
  15. [[local-dev-why]]
  16. === When would I use this setup?
  17. Use this setup if you want to quickly spin up {es} (and {kib}) for local development or testing.
  18. For example you might:
  19. * Want to run a quick test to see how a feature works.
  20. * Follow a tutorial or guide that requires an {es} cluster, like our <<getting-started,quick start guide>>.
  21. * Experiment with the {es} APIs using different tools, like the Dev Tools Console, cURL, or an Elastic programming language client.
  22. * Quickly spin up an {es} cluster to test an executable https://github.com/elastic/elasticsearch-labs/tree/main/notebooks#readme[Python notebook] locally.
  23. [discrete]
  24. [[local-dev-prerequisites]]
  25. === Prerequisites
  26. If you don't have Docker installed, https://www.docker.com/products/docker-desktop[download and install Docker Desktop] for your operating system.
  27. [discrete]
  28. [[local-dev-env-vars]]
  29. === Set environment variables
  30. Configure the following environment variables.
  31. [source,sh]
  32. ----
  33. export ELASTIC_PASSWORD="<ES_PASSWORD>" # password for "elastic" username
  34. export KIBANA_PASSWORD="<KIB_PASSWORD>" # Used _internally_ by Kibana, must be at least 6 characters long
  35. ----
  36. [discrete]
  37. [[local-dev-create-docker-network]]
  38. === Create a Docker network
  39. To run both {es} and {kib}, you'll need to create a Docker network:
  40. [source,sh]
  41. ----
  42. docker network create elastic-net
  43. ----
  44. [discrete]
  45. [[local-dev-run-es]]
  46. === Run {es}
  47. Start the {es} container with the following command:
  48. ifeval::["{release-state}"=="unreleased"]
  49. WARNING: Version {version} has not yet been released.
  50. No Docker image is currently available for {es} {version}.
  51. endif::[]
  52. [source,sh,subs="attributes"]
  53. ----
  54. docker run -p 127.0.0.1:9200:9200 -d --name elasticsearch --network elastic-net \
  55. -e ELASTIC_PASSWORD=$ELASTIC_PASSWORD \
  56. -e "discovery.type=single-node" \
  57. -e "xpack.security.http.ssl.enabled=false" \
  58. -e "xpack.license.self_generated.type=trial" \
  59. {docker-image}
  60. ----
  61. [discrete]
  62. [[local-dev-run-kib]]
  63. === Run {kib} (optional)
  64. To run {kib}, you must first set the `kibana_system` password in the {es} container.
  65. [source,sh,subs="attributes"]
  66. ----
  67. # configure the Kibana password in the ES container
  68. curl -u elastic:$ELASTIC_PASSWORD \
  69. -X POST \
  70. http://localhost:9200/_security/user/kibana_system/_password \
  71. -d '{"password":"'"$KIBANA_PASSWORD"'"}' \
  72. -H 'Content-Type: application/json'
  73. ----
  74. // NOTCONSOLE
  75. Start the {kib} container with the following command:
  76. ifeval::["{release-state}"=="unreleased"]
  77. WARNING: Version {version} has not yet been released.
  78. No Docker image is currently available for {es} {version}.
  79. endif::[]
  80. [source,sh,subs="attributes"]
  81. ----
  82. docker run -p 127.0.0.1:5601:5601 -d --name kibana --network elastic-net \
  83. -e ELASTICSEARCH_URL=http://elasticsearch:9200 \
  84. -e ELASTICSEARCH_HOSTS=http://elasticsearch:9200 \
  85. -e ELASTICSEARCH_USERNAME=kibana_system \
  86. -e ELASTICSEARCH_PASSWORD=$KIBANA_PASSWORD \
  87. -e "xpack.security.enabled=false" \
  88. -e "xpack.license.self_generated.type=trial" \
  89. {kib-docker-image}
  90. ----
  91. [NOTE]
  92. ====
  93. The service is started with a trial license. The trial license enables all features of Elasticsearch for a trial period of 30 days. After the trial period expires, the license is downgraded to a basic license, which is free forever. If you prefer to skip the trial and use the basic license, set the value of the `xpack.license.self_generated.type` variable to basic instead. For a detailed feature comparison between the different licenses, refer to our https://www.elastic.co/subscriptions[subscriptions page].
  94. ====
  95. [discrete]
  96. [[local-dev-connecting-clients]]
  97. == Connecting to {es} with language clients
  98. To connect to the {es} cluster from a language client, you can use basic authentication with the `elastic` username and the password you set in the environment variable.
  99. You'll use the following connection details:
  100. * **{es} endpoint**: `http://localhost:9200`
  101. * **Username**: `elastic`
  102. * **Password**: `$ELASTIC_PASSWORD` (Value you set in the environment variable)
  103. For example, to connect with the Python `elasticsearch` client:
  104. [source,python]
  105. ----
  106. import os
  107. from elasticsearch import Elasticsearch
  108. username = 'elastic'
  109. password = os.getenv('ELASTIC_PASSWORD') # Value you set in the environment variable
  110. client = Elasticsearch(
  111. "http://localhost:9200",
  112. basic_auth=(username, password)
  113. )
  114. print(client.info())
  115. ----
  116. Here's an example curl command using basic authentication:
  117. [source,sh,subs="attributes"]
  118. ----
  119. curl -u elastic:$ELASTIC_PASSWORD \
  120. -X PUT \
  121. http://localhost:9200/my-new-index \
  122. -H 'Content-Type: application/json'
  123. ----
  124. // NOTCONSOLE
  125. [discrete]
  126. [[local-dev-next-steps]]
  127. === Next steps
  128. Use our <<getting-started,quick start guide>> to learn the basics of {es}: how to add data and query it.
  129. [discrete]
  130. [[local-dev-production]]
  131. === Moving to production
  132. This setup is not suitable for production use. For production deployments, we recommend using our managed service on Elastic Cloud. https://cloud.elastic.co/registration[Sign up for a free trial] (no credit card required).
  133. Otherwise, refer to https://www.elastic.co/guide/en/elasticsearch/reference/current/install-elasticsearch.html[Install {es}] to learn about the various options for installing {es} in a self-managed production environment, including using Docker.