基于 JumpServer 容器化部署 ES 集群

1 确保 JumpServer 容器环境正常

bash 复制代码
docker ps

2 编写文件

进入 JumpServer 的 /opt/jumpserver-xxx/compose 目录,备份 es.yml 文件并编辑 es.yml文件

bash 复制代码
services:
  es01:
    image: docker.elastic.co/elasticsearch/elasticsearch:7.17.25
    container_name: jms_es01
    hostname: es01
    restart: always
    ports:
      - 9200:9200
    volumes:
      - ${VOLUME_DIR}/elasticsearch/es01/data:/usr/share/elasticsearch/data
      - ${VOLUME_DIR}/elasticsearch/es01/logs:/usr/share/elasticsearch/logs
    environment:
      TZ: ${TZ:-Asia/Shanghai}
      cluster.name: jms-es-cluster
      node.name: es01
      node.roles: master,data,ingest
      discovery.seed_hosts: es01,es02,es03
      cluster.initial_master_nodes: es01,es02,es03
      network.host: 0.0.0.0
      bootstrap.memory_lock: "false"
      xpack.security.enabled: "false"
      TAKE_FILE_OWNERSHIP: "true"
      ES_JAVA_OPTS: "-Xms512m -Xmx512m"
    ulimits:
      memlock:
        soft: '-1'
        hard: '-1'
    healthcheck:
      test: "curl -sL http://localhost:9200 > /dev/null"
      interval: 10s
      timeout: 5s
      retries: 3
      start_period: 60s
    networks:
      - net

  es02:
    image: docker.elastic.co/elasticsearch/elasticsearch:7.17.25
    container_name: jms_es02
    hostname: es02
    restart: always
    ports:
      - 9201:9200
    volumes:
      - ${VOLUME_DIR}/elasticsearch/es02/data:/usr/share/elasticsearch/data
      - ${VOLUME_DIR}/elasticsearch/es02/logs:/usr/share/elasticsearch/logs
    environment:
      TZ: ${TZ:-Asia/Shanghai}
      cluster.name: jms-es-cluster
      node.name: es02
      node.roles: master,data,ingest
      discovery.seed_hosts: es01,es02,es03
      cluster.initial_master_nodes: es01,es02,es03
      network.host: 0.0.0.0
      bootstrap.memory_lock: "false"
      xpack.security.enabled: "false"
      TAKE_FILE_OWNERSHIP: "true"
      ES_JAVA_OPTS: "-Xms512m -Xmx512m"
    ulimits:
      memlock:
        soft: '-1'
        hard: '-1'
    healthcheck:
      test: "curl -sL http://localhost:9200 > /dev/null"
      interval: 10s
      timeout: 5s
      retries: 3
      start_period: 60s
    networks:
      - net

  es03:
    image: docker.elastic.co/elasticsearch/elasticsearch:7.17.25
    container_name: jms_es03
    hostname: es03
    restart: always
    ports:
      - 9202:9200
    volumes:
      - ${VOLUME_DIR}/elasticsearch/es03/data:/usr/share/elasticsearch/data
      - ${VOLUME_DIR}/elasticsearch/es03/logs:/usr/share/elasticsearch/logs
    environment:
      TZ: ${TZ:-Asia/Shanghai}
      cluster.name: jms-es-cluster
      node.name: es03
      node.roles: master,data,ingest
      discovery.seed_hosts: es01,es02,es03
      cluster.initial_master_nodes: es01,es02,es03
      network.host: 0.0.0.0
      bootstrap.memory_lock: "false"
      xpack.security.enabled: "false"
      TAKE_FILE_OWNERSHIP: "true"
      ES_JAVA_OPTS: "-Xms512m -Xmx512m"
    ulimits:
      memlock:
        soft: '-1'
        hard: '-1'
    healthcheck:
      test: "curl -sL http://localhost:9200 > /dev/null"
      interval: 10s
      timeout: 5s
      retries: 3
      start_period: 60s
    networks:
      - net

networks:
  net:
    external: true
    name: jms_net

3 启动 ES 容器

bash 复制代码
# 调整 vm.max_map_count 太小
echo "vm.max_map_count=262144" | sudo tee -a /etc/sysctl.conf
sysctl -p
# 启动 es 容器
docker compose -f es.yml up -d
# 查看容器运行状态
docker ps | grep jms_es

4 检查 ES 容器状态

bash 复制代码
# 检查节点状态
curl -X GET "http://localhost:9200/_cat/nodes?v&pretty"
# 检查集群健康
curl -X GET "http://localhost:9200/_cluster/health?pretty"
# 检查索引
curl -X GET "http://localhost:9200/_cat/indices?v&pretty"
  • localhost:9200 是 ES01 节点,其他端口(9201、9202)也可以分别查询。
  • 命令会显示每个节点的名称、角色、内存、CPU、主节点状态等。
  • status = green → 集群健康,所有主分片和副本分片正常。
  • status = yellow → 主分片正常,但副本分片未分配(通常是单节点集群才会出现)。
  • status = red → 出现数据丢失或节点未启动,需要检查日志。
  • 可以看到所有索引状态是否为 open
  • 如果有 closedred 状态,需要进一步排查。

5 将 ES 各个节点添加至 JumpServer 命令存储

1.依次点击 系统设置 -- 存储设置 -- 命令存储 -- 创建

2.设置为默认存储

3.依次点击 系统设置 -- 组件设置 -- 组件列表 -- 全选 -- 更多操作 -- 命令存储 -- ES3 -- 确认

6 验证 ES 节点是否正常存储命令

1.去 web cli 命令行输入命令验证 es 存储

2.依次点击 审计台 -- 会话命令 -- 命令存储 -- ES3

相关推荐
老陈头聊SEO1 小时前
生成引擎优化(GEO)引领内容创作与用户体验的转型之路
其他·搜索引擎·seo优化
无忧智库1 小时前
基于C4ISR与数据链的智慧应急体系:从“透明战场”到“透明城市”的数字化指挥解决方案(170页PPT)
大数据·人工智能·智慧城市
奇点爆破XC1 小时前
Hadoop大数据生态(Ambari管理)组件服务详解
大数据·hadoop·ambari
量化君也2 小时前
快速入门量化交易都要学些什么?
大数据·人工智能·python·算法·金融
吴卫斌2 小时前
行业ETF轮动策略实战(二):精选候选池——打造你的赛道武器库
大数据·python·股票·量化交易
方向研究2 小时前
破解蒙代尔三角
大数据
大任视点2 小时前
从云经济学之父,到人工智能经济学奠基人
大数据·人工智能·业界资讯
Antom全球收单2 小时前
跨境B2B支付平台与全球收单平台有什么区别?一文讲清
大数据
科技风向标go2 小时前
QYResearch联合发布:《2026室外网络摄像头行业白皮书》格行视精灵成用户室外硬核环境首选监控
大数据·网络·安全·监控·户外安防
珠***格2 小时前
Ⅱ型边缘网关|易部署、易扩容、易改造
大数据·人工智能·分布式·能源·边缘计算