此处部署为单个服务器启动三个elasticsearch容器

问题:本打算在三个服务器上单独部署elasticsearch 容器,elasticsearch.yml 注册用的宿主机ip,但是容器之间通信发现用的是容器内部ip,导致节点之间通信失败,只能发现master节点,待大佬们解疑答惑

  • 修改 max_map_count 否则启动失败,提示该值设置为262144

    • cat /proc/sys/vm/max_map_count
    • sysctl -w vm.max_map_count=262144
  • 分别创建三个节点配置文件挂载目录

  • 拉取 elasticsearch 镜像

    • docker pull elasticsearch:7.14.0
    • 先启动一个容器,并将配置文件复制出来

    • docker run --name es01 -d -e ES_JAVA_OPTS="-Xms512m -Xmx512m"  -v /opt/es01/config/elasticsearch.yml:/usr/share/elasticsearch/config/elasticsearch.yml -p 9200:9200 -p 9300:9300 elasticsearch:7.14.0
    • docker cp es01:/usr/share/elasticsearch/config/elasticsearch.yml /opt/es01/config
  • 修改 es01 elasticsearch.yml

    • # 集群名称
      cluster.name: es-cluster
      # 节点名称
      node.name: es-node1
      # 启用该物理机器所有网卡网络访问
      network.host: 0.0.0.0
      http.host: 0.0.0.0
      # 跨域
      http.cors.enabled: true
      http.cors.allow-origin: "*"
      # 当前节点是否可以被选举为master节点,是:true、否:false
      node.master: true
      # 当前节点是否用于存储数据,是:true、否:false
      node.data: true
      # 设置节点之间通信的端口
      transport.tcp.port: 9300
      # es7.x 之后新增的配置,写入候选主节点的设备地址,在开启服务后可以被选为主节点
      discovery.seed_hosts: 192.168.202.128:9300
      # es7.x 之后新增的配置,初始化一个新的集群时需要此配置来选举master
      cluster.initial_master_nodes: es-node1
      # elasticsearch和其他节点通信的地址,如果不设置的话 会自动获取
      network.publish_host: 192.168.202.128
      # host地址,默认为network.host
      transport.host: 0.0.0.0
      # 设置这个集群,有多少个节点有master候选资格,如果集群较大官方建议为2-4个
      discovery.zen.minimum_master_nodes: 1
    • docker restart es01

  • 复制 elasticsearch.yml 到其他两个 es 挂载目录

    • es02 elasticsearch.yml

    • cluster.name: es-cluster
      node.name: es-node2
      network.host: 0.0.0.0
      http.host: 0.0.0.0
      http.cors.enabled: true
      http.cors.allow-origin: "*"
      node.master: true
      node.data: true
      transport.tcp.port: 9301
      discovery.seed_hosts: 192.168.202.128:9300
      cluster.initial_master_nodes: es-node1
      network.publish_host: 192.168.202.128
      transport.host: 0.0.0.0
      discovery.zen.minimum_master_nodes: 1
    • es03 elasticsearch.yml

    • cluster.name: es-cluster
      node.name: es-node3
      network.host: 0.0.0.0
      http.host: 0.0.0.0
      http.cors.enabled: true
      http.cors.allow-origin: "*"
      node.master: true
      node.data: true
      transport.tcp.port: 9302
      discovery.seed_hosts: 192.168.202.128:9300
      cluster.initial_master_nodes: es-node1
      network.publish_host: 192.168.202.128
      transport.host: 0.0.0.0
      discovery.zen.minimum_master_nodes: 1
    • 启动es02 、 es03

    • docker run --name es02 -d -e ES_JAVA_OPTS="-Xms512m -Xmx512m"  -v /opt/es02/config/elasticsearch.yml:/usr/share/elasticsearch/config/elasticsearch.yml -p 9201:9200 -p 9301:9300 elasticsearch:7.14.0
      
      docker run --name es03 -d -e ES_JAVA_OPTS="-Xms512m -Xmx512m"  -v /opt/es03/config/elasticsearch.yml:/usr/share/elasticsearch/config/elasticsearch.yml -p 9202:9200 -p 9302:9300 elasticsearch:7.14.0
    • es 启动较慢,别着急 ,访问接口 http://192.168.202.128:9200/_cat/nodes

    • 172.17.0.2 72 97 1 0.08 0.11 0.14 cdfhilmrstw * es-node1
      172.17.0.4 53 97 1 0.08 0.11 0.14 cdfhilmrstw - es-node3
      172.17.0.3 69 97 1 0.08 0.11 0.14 cdfhilmrstw - es-node2
    • 显示以上信息表示集群搭建成功

  • 安装 elasticsearch-head 可视化界面

    • #拉取镜像
      docker pull mobz/elasticsearch-head:5 #创建容器
      docker create --name elasticsearch-head -p 9100:9100 mobz/elasticsearch-head:5 #启动容器
      docker start elasticsearch-head
      or
      docker start 容器id (docker ps -a 查看容器id )
    • 启动成功后访问 http://192.168.202.128:9100/

docker 安装 elasticsearch 集群的更多相关文章

  1. Docker部署Elasticsearch集群

    http://blog.sina.com.cn/s/blog_8ea8e9d50102wwik.html Docker部署Elasticsearch集群 参考文档: https://hub.docke ...

  2. Elasticsearch使用系列-Docker搭建Elasticsearch集群

    Elasticsearch使用系列-ES简介和环境搭建 Elasticsearch使用系列-ES增删查改基本操作+ik分词 Elasticsearch使用系列-基本查询和聚合查询+sql插件 Elas ...

  3. docker安装hadoop集群

    docker安装hadoop集群?图啥呢?不图啥,就是图好玩.本篇博客主要是来教大家如何搭建一个docker的hadoop集群.不要问 为什么我要做这么无聊的事情,答案你也许知道,因为没有女票.... ...

  4. Docker安装Consul集群

    Docker 安装Consul集群 使用windows 环境,Docker desktop community 构建consul集群. 1.docker 容器网络 docker安装后,默认会创建三种网 ...

  5. 基于docker安装pxc集群

    基于docker安装pxc集群 一.PXC 集群的安装 PXC集群比较特殊,需要安装在 linux 或 Docker 之上.这里使用 Docker进行安装! Docker的镜像仓库中包含了 PXC数据 ...

  6. 使用Docker搭建Elasticsearch集群环境

    本篇文章首发于头条号单机如何搭建Elasticsearch集群?使用容器技术快速构建集群环境,欢迎关注头条号和微信公众号"大数据技术和人工智能"(微信搜索bigdata_ai_te ...

  7. k8s上安装elasticsearch集群

    官方文档地址:https://www.elastic.co/guide/en/cloud-on-k8s/current/k8s-quickstart.html yaml文件地址:https://dow ...

  8. 基于docker搭建elasticsearch集群

    es集群的搭建 - 基于单机搭建elasticsearch集群见官网 https://www.elastic.co/guide/en/elasticsearch/reference/current/d ...

  9. Centos8 Docker部署ElasticSearch集群

    ELK部署 部署ElasticSearch集群 1.拉取镜像及批量生成配置文件 # 拉取镜像 [root@VM-24-9-centos ~]# docker pull elasticsearch:7. ...

  10. 利用 docker 部署 elasticsearch 集群(单节点多实例)

    文章目录 1.环境介绍 2.拉取 `elasticserach` 镜像 3.创建 `elasticsearch` 数据目录 4.创建 `elasticsearch` 配置文件 5.配置JVM线程数量限 ...

随机推荐

  1. 图解翻转单向链表,超详细(python语言实现)

    节点类: 1 class ListNode(object): 2 def __init__(self, x): 3 self.val = x 4 slef.next = None 反转单向链表的函数如 ...

  2. java spring boot 2 开发实战 mybtis 基础部份从搭建到第一个完整测试(从环境到测试用例二部份)

    本案例是java  sping boot  2.2.1 mybtis 基础部份 第一步搭建环境:安装依赖 由于我们公司项目是1.8 环境不能乱,我现在自己的电脑是1.8环境,所以本次整理的boot 代 ...

  3. Umov移动方块-scratch编程作品

    程序说明: <Umov移动方块>是一款基于Scratch平台制作的小游戏.在这个游戏中,玩家将面对一个3×3的圆圈棋盘,并通过鼠标控制蓝色方块在这些圆圈中灵活移动.游戏的挑战在于,舞台的四 ...

  4. 【Java】JDBC Part1 数据库连接的演变

    环境搭建 使用Maven工程的依赖项,如果普通工程就点注释的地址下载jar包即可 <dependencies> <!-- https://mvnrepository.com/arti ...

  5. 【FastDFS】环境搭建 02 测试

    自带工具测试: 编辑客户端配置文件: vim client.conf 配置完成后,随便上传一个图片到root目录下 运行FastFDS文件上传程序,并将客户端配置文件作为加载参数1,要上传的图片文件位 ...

  6. 基于MybatisPlus的简单分页查询和条件分页查询

    分页查询 分析: 分析文档要求 查看前端传递给后台的参数 分析参数进行编码 后台返回给前端的数据 思路 浏览器 - > Controller层 - > Service层 - > Ma ...

  7. 什么是snapshot isolation

    数据库常见的4种事务隔离级别: (源自:(34条消息) 8. 事务隔离级别: 总结_oyw5201314ck的博客-CSDN博客_ck事务隔离) 大多数的数据库默认的事务隔离级别是Repeatable ...

  8. 不符合自身利益的科学讨论是否应该得到尊重—— 读《自家员工质疑Jeff Dean领衔的Nature论文被解雇,谷歌:我们彻查了,质疑不符合标准》有感

    读了一篇博文<自家员工质疑Jeff Dean领衔的Nature论文被解雇,谷歌:我们彻查了,质疑不符合标准>,其问大致是说Google提了一篇使用reinforcement learnin ...

  9. @ComponentScan

    @ComponentScan 是一个注解,用于Spring框架,它允许开发者指定Spring应该扫描哪个包或包下的子包来寻找组件(如@Component.@Service.@Repository等注解 ...

  10. 【CDQ分治】【模板】三维偏序(陌上花开)

    P3810 [模板]三维偏序(陌上花开) - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) #include <bits/stdc++.h> using namespace ...