docker 集群部署elasticsearch
时间:2021-11-04 21:20:33 +0800 CST 浏览:574

部署环境

  • system: centos 7
  • nodes: 10.1.209.1, 10.1.209.2, 10.1.209.3

拉取镜像

docker pull elasticsearch:7.13.4

数据目录

#存放配置文件的文件夹
mkdir -p /home/elasticsearch/{config,data,log,plugins}
chmod 755 -R /home/elasticsearch

配置文件

配置文件路径: /home/elasticsearch/config/elasticsearch.yml
分别在三台节点机器上创建配置文件,并修改配置文件中的cluster.namenode.namenetwork.publish_host字段即可。

#集群名称
cluster.name: my-es
#当前该节点的名称
node.name: node-x
#是不是有资格竞选主节点
node.master: true
#是否存储数据
node.data: true
#最大集群节点数
node.max_local_storage_nodes: 3
#给当前节点自定义属性(可以省略)
#node.attr.rack: r1
#数据存档位置
path.data: /usr/share/elasticsearch/data
#日志存放位置
path.logs: /usr/share/elasticsearch/log
#是否开启时锁定内存(默认为是)
#bootstrap.memory_lock: true
#设置网关地址,我是被这个坑死了,这个地址我原先填写了自己的实际物理IP地址,
#然后启动一直报无效的IP地址,无法注入9300端口,这里只需要填写0.0.0.0
network.host: 0.0.0.0
#设置其它结点和该结点交互的ip地址,如果不设置它会自动判断,值必须是个真实的ip地址,设置当前物理机地址,
#如果是docker安装节点的IP将会是配置的IP而不是docker网管ip
network.publish_host: 10.1.209.x
#设置映射端口
http.port: 9200
#内部节点之间沟通端口
transport.tcp.port: 9300
#集群发现默认值为127.0.0.1:9300,如果要在其他主机上形成包含节点的群集,如果搭建集群则需要填写
#es7.x 之后新增的配置,写入候选主节点的设备地址,在开启服务后可以被选为主节点,也就是说把所有的节点都写上
discovery.seed_hosts: ["10.1.209.1:9300","10.1.209.2:9300","10.1.209.3:9300"]
#当你在搭建集群的时候,选出合格的节点集群,有些人说的太官方了,
#其实就是,让你选择比较好的几个节点,在你节点启动时,在这些节点中选一个做领导者,
#如果你不设置呢,elasticsearch就会自己选举,这里我们把三个节点都写上
cluster.initial_master_nodes: ["node-1","node-2","node-3"]
#在群集完全重新启动后阻止初始恢复,直到启动N个节点
#简单点说在集群启动后,至少复活多少个节点以上,那么这个服务才可以被使用,否则不可以被使用,
gateway.recover_after_nodes: 2
#删除索引是是否需要显示其名称,默认为显示
#action.destructive_requires_name: true

启动集群

分别在三台节点机器执行以下命令启动服务即可,ES_JAVA_OPTS根据自身需求修改。

docker run -e ES_JAVA_OPTS="-Xms512m -Xmx512m" -d -p 9200:9200 -p 9300:9300 --restart always -v /home/elasticsearch/config/elasticsearch.yml:/usr/share/elasticsearch/config/elasticsearch.yml -v /home/elasticsearch/plugins:/usr/share/elasticsearch/plugins -v /home/elasticsearch/data:/usr/share/elasticsearch/data/ -v /home/elasticsearch/log:/usr/share/elasticsearch/log --name es-node-3 elasticsearch:7.13.4

验证是否搭建成功

http://10.1.209.x:9200/_cat/nodes?pretty

问题

max virtual memory areas vm.max_map_count [65530] is too low, increase to at least

vim /etc/sysctl.conf
vm.max_map_count=655360
#保存退出,并刷新系统配置
sysctl -p /etc/sysctl.conf/


如果这篇文章对你有所帮助,可以通过下边的“打赏”功能进行小额的打赏。

本网站部分内容来源于互联网,如有侵犯版权请来信告知,我们将立即处理。


来说两句吧