使用 docker-compose 启动 es 集群 + kibana

编写 docker-compose yaml

yaml 复制代码
version: 'v3'
services:
  elasticsearch-node1:
    image: elasticsearch:7.17.24
    container_name: 'elasticsearch-node1'
    ports:
      - "9200:9200"
      - "9300:9300"
    environment:
      - node.name=elasticsearch-node1
      - cluster.name=my-es-cluster
      - discovery.seed_hosts=elasticsearch-node2,elasticsearch-node3
      - cluster.initial_master_nodes=elasticsearch-node1,elasticsearch-node2,elasticsearch-node3
      - bootstrap.memory_lock=true
      - "ES_JAVA_OPTS=-Xms512m -Xmx512m"
    ulimits:
      memlock:
        soft: -1
        hard: -1
    networks:
      - custom-es
  elasticsearch-node2:
    image: elasticsearch:7.17.24
    container_name: elasticsearch-node2
    ports:
      - "9201:9200"
      - "9301:9300"
    environment:
      - node.name=elasticsearch-node2
      - cluster.name=my-es-cluster
      - discovery.seed_hosts=elasticsearch-node1,elasticsearch-node3
      - cluster.initial_master_nodes=elasticsearch-node1,elasticsearch-node2,elasticsearch-node3
      - bootstrap.memory_lock=true
      - "ES_JAVA_OPTS=-Xms512m -Xmx512m"
    ulimits:
      memlock:
        soft: -1
        hard: -1
    networks:
      - custom-es
  elasticsearch-node3:
    image: elasticsearch:7.17.24
    container_name: elasticsearch-node3
    ports:
      - "9202:9200"
      - "9302:9300"
    environment:
      - node.name=elasticsearch-node3
      - cluster.name=my-es-cluster
      - discovery.seed_hosts=elasticsearch-node1,elasticsearch-node2
      - cluster.initial_master_nodes=elasticsearch-node1,elasticsearch-node2,elasticsearch-node3
      - bootstrap.memory_lock=true
      - "ES_JAVA_OPTS=-Xms512m -Xmx512m"
    ulimits:
      memlock:
        soft: -1
        hard: -1
    networks:
      - custom-es
  my-es-cluster-kibana:
    container_name: my-es-cluster-kibana
    image: kibana:7.17.24
    ports:
      - "5601:5601"
    environment:
      - ELASTICSEARCH_HOSTS=http://elasticsearch-node1:9200
    networks:
      - custom-es
    depends_on:
      - elasticsearch-node1
      - elasticsearch-node2
      - elasticsearch-node3
networks:
  custom-es:
    driver: bridge

编写 docker-compose 然后在命令行启动这个 docker-compose

启动 docker-compose

docker-compose -f docker-compose.yml -d up

这个命令可以在后台启动一个compose,里面包含 es3个节点的集群+kibana

然后在 chrome 中查询当前的集群信息

分别是

bash 复制代码
# 查询节点信息
curl http://127.0.0.1:9200/_cat/nodes
# 访问 kibana
curl http://127.0.0.1:5601

当我们输入以后可以看到这样的街面就可以正常使用 es 和 kibana 了

关闭启动的docker-compose

docker-compose -f docker-compose.yaml down

相关推荐
IT成长日记9 分钟前
【Docker基础】Docker数据持久化与卷(Volume)介绍
运维·docker·容器·数据持久化·volume·
热爱生活的猴子12 分钟前
阿里云服务器正确配置 Docker 国内镜像的方法
服务器·阿里云·docker
FrankYoou4 小时前
Jenkins 与 GitLab CI/CD 的核心对比
java·docker
隆里卡那唔4 小时前
在dify中通过http请求neo4j时为什么需要将localhost变为host.docker.internal
http·docker·neo4j
疯子的模样4 小时前
Docker 安装 Neo4j 保姆级教程
docker·容器·neo4j
大只鹅5 小时前
解决 Spring Boot 对 Elasticsearch 字段没有小驼峰映射的问题
spring boot·后端·elasticsearch
Lpy25698 小时前
Docker Desktop 安装到D盘(包括镜像下载等)+ 汉化
运维·docker·容器
hunjinYang9 小时前
Tomcat镜像实战:掌握Dockerfile的编写以及发布项目
docker·tomcat
好奇的菜鸟9 小时前
Docker 配置项详解与示例
运维·docker·容器
HGW68914 小时前
基于 Elasticsearch 实现地图点聚合
java·elasticsearch·高德地图