如何在docker中部署Elasticsearch集群和kibana

Posted tryc

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何在docker中部署Elasticsearch集群和kibana相关的知识,希望对你有一定的参考价值。

做实验时需要了解Elasticsearch集群如何操作?通过使用docker-compose可以批量创建docker容器,启动ES集群。

先配置文件docker-compose.yml文件如下:

 1 version: ‘2.2‘
 2 networks:
 3   esnet:
 4 services:
 5   es00:
 6     image: docker.elastic.co/elasticsearch/elasticsearch:6.5.1
 7     container_name: es00
 8     environment:
 9       - cluster.name=esdocker-cluster
10       - node.name=node-00
11       - bootstrap.memory_lock=true
12       - "ES_JAVA_OPTS=-Xms512m -Xmx512m"
13       - http.cors.enabled=true
14       - http.cors.allow-origin=*
15     ulimits:
16       memlock:
17         soft: -1
18         hard: -1
19     volumes:
20       - .es00:/usr/share/elasticsearch/data
21     ports:
22       - 9200:9200
23       - 9300:9300
24     networks:
25       - esnet
26   es01:
27     image: docker.elastic.co/elasticsearch/elasticsearch:6.5.1
28     container_name: es01
29     environment:
30       - cluster.name=esdocker-cluster
31       - node.name=node-01
32       - bootstrap.memory_lock=true
33       - "ES_JAVA_OPTS=-Xms512m -Xmx512m"
34       - "discovery.zen.ping.unicast.hosts=es00"
35     ulimits:
36       memlock:
37         soft: -1
38         hard: -1
39     volumes:
40       - .es01:/usr/share/elasticsearch/data
41     ports:
42       - 9201:9200
43       - 9301:9300
44     networks:
45       - esnet
46     depends_on:
47       - es00
48   es02:
49     image: docker.elastic.co/elasticsearch/elasticsearch:6.5.1
50     container_name: es02
51     environment:
52       - cluster.name=esdocker-cluster
53       - node.name=node-02
54       - bootstrap.memory_lock=true
55       - "ES_JAVA_OPTS=-Xms512m -Xmx512m"
56       - "discovery.zen.ping.unicast.hosts=es00"
57     ulimits:
58       memlock:
59         soft: -1
60         hard: -1
61     volumes:
62       - .es02:/usr/share/elasticsearch/data
63     ports:
64       - 9202:9200
65       - 9302:9300
66     networks:
67       - esnet
68     depends_on:
69       - es00
70 
71   kibana:
72     image: docker.elastic.co/kibana/kibana:6.5.1
73     container_name: kibana
74     environment:
75       - SERVER_NAME=kibana
76       - ELASTICSEARCH_URL=http://es00:9200
77       - XPACK_MONITORING_ENABLED=true
78     ports:
79       - 5601:5601
80     networks:
81       - esnet
82     depends_on:
83       - es00
84     external_links:
85       - es00

说明:

第一个networks貌似得放前面,不然后面网络找不到es00,貌似这是和官方文档唯一的区别,坑了好久。
也可以像下面这样写,但是必须在启动之前先创建docker网络,运行命令(docker network create esnet)即可。
1 networks:
2   esnet:
3     external: true

 

运行docker-compose up即可启动Elasticsearch集群和kibana。

docker-compose down 删除docker。

 

参考官方文档:

https://www.elastic.co/guide/en/kibana/6.5/docker.html#environment-variable-config

https://www.elastic.co/guide/en/kibana/6.5/docker.html#environment-variable-config

 


以上是关于如何在docker中部署Elasticsearch集群和kibana的主要内容,如果未能解决你的问题,请参考以下文章

Elasticsearch:如何在 Docker 容器中安装 Elastic Stack

【教程】在Docker中部署ES(elasticsearch)

Elasticsearch:使用 Docker compose 来一键部署 Elastic Stack 8.x

elasticsearch7 docker集群部署

Elasticsearch:保护你的 Elasticsearch 实例 - 如何使用带有内置证书的 Docker 镜像

Elasticsearch:保护你的 Elasticsearch 实例 - 如何使用带有内置证书的 Docker 镜像