- 拉取镜像
docker pull docker.io/elasticsearch
- 建立挂载文件夹
其中elasticsearch.yml
文件配置如下:
#集群名称
cluster.name: escluster
#节点名
node.name: node-1
#设置绑定的ip地址,可以是ipv4或ipv6的,默认为0.0.0.0,指绑定这台机器的任何一个ip
network.bind_host: 0.0.0.0
#设置其它节点和该节点交互的ip地址,如果不设置它会自动判断,值必须是个真实的ip地址
# network.publish_host: X.X.X.X
#设置对外服务的http端口,默认为9200
http.port: 9200
#设置节点之间交互的tcp端口,默认是9300
transport.tcp.port: 9300
#是否允许跨域REST请求
http.cors.enabled: true
#允许 REST 请求来自何处
http.cors.allow-origin: "*"
#节点角色设置
node.master: true
node.data: true
#有成为主节点资格的节点列表
# discovery.zen.ping.unicast.hosts: ["X.X.X.X:9300"]
#集群中一直正常运行的,有成为master节点资格的最少节点数(默认为1),(totalnumber of master-eligible nodes / 2 + 1)
discovery.zen.minimum_master_nodes: 1
-
在docker中配置共享文件夹
- 创建并运行容器
docker run --name elasticsearch -p 9200:9200 -p 9300:9300 -v G:\\ElasticSearch\\config\\elasticsearch.yml:/usr/share/elasticsearch/config/elasticsearch.yml -v G:\\ElasticSearch\\data:/usr/share/elasticsearch/data docker.io/elasticsearch:latest
-
部署成功
- 访问查看结果
curl -G http://localhost:9200
{
"name" : "vhg0jb6",
"cluster_name" : "elasticsearch",
"cluster_uuid" : "G1vMafgjTbWk_6b3wOCW3w",
"version" : {
"number" : "5.6.12",
"build_hash" : "cfe3d9f",
"build_date" : "2018-09-10T20:12:43.732Z",
"build_snapshot" : false,
"lucene_version" : "6.6.1"
},
"tagline" : "You Know, for Search"
}