docker-compose安装emqx集群(最新)(host模式)

机器:

10.60.0.20

10.60.0.21

10.60.0.22

一、三台机子都配置域名(/etc/hosts)

bash 复制代码
10.60.0.20 node1.emqx.io
10.60.0.22 node3.emqx.io
10.60.0.21 node2.emqx.io

二、docker-compose.yml(10.60.0.21)

其他两台机子自己替换EMQX_NODE_NAME(节点名)

bash 复制代码
version: '3.9'

services:
  emqx1:
    image: emqx:5.6.1
    container_name: emqx1
    environment:
      - "TZ=Asia/Shanghai"
      - "EMQX_NODE_NAME=emqx@node1.emqx.io"
      - "EMQX_CLUSTER__DISCOVERY_STRATEGY=static"
      - "EMQX_CLUSTER__STATIC__SEEDS=[emqx@node1.emqx.io,emqx@node2.emqx.io,emqx@node3.emqx.io]"
    healthcheck:
      test: ["CMD", "/opt/emqx/bin/emqx_ctl", "status"]
      interval: 5s
      timeout: 25s
      retries: 5
    ports:
      - 1883:1883
      - 8083:8083
      - 8084:8084
      - 8883:8883
      - 18083:18083
 #   extra_hosts:
      # 允许容器可以使用的host访问其余节点
#       - node2.emqx.io:10.60.0.21
#       - node3.emqx.io:10.60.0.22
    volumes:
      - ./logs:/opt/emqx/log
      - ./data:/opt/emqx/data
    privileged: true
    network_mode: host
    restart: "on-failure: 10"
    logging:
      driver: json-file
      options:
        max-size: 10m
        max-file: 3

三、启动

第一次启动应该会失败,因为data目录我是直接启动时自动创建的,查看容器日志会提示/opt/emqx/data/configs的权限不够。

解决办法:修改data及其子目录权限为777,再重新执行docker-compose up -d 启动容器。

另一种办法就是先创建data,赋权限777,在执行docker-compose up -d 启动容器

四、启动成功后查看emqx是否加入集群(10.60.0.20),我21和22分别叫emqx2,emqx3

bash 复制代码
docker exec -it emqx1 sh -c "emqx_ctl cluster status"

正确的结果(如果三个容器都启动了,可以看见三个节点都加入了。如果只启动了一个节点,集群里running状态的也只有当前节点,另外两个节点就在stop,以下是三个都启动成功)

如果执行以上命令是提示ping不通,像下面那样,那就是你的hosts没配对(Node 'emqx@node1.emqx.io' not responding to pings.)

原因是什么?就是你要为@符号之后的域名配解析ip,所以才有第一步的操作

五、控制台展示

相关推荐
qq_411262425 分钟前
esp32c3的at固件,开启了tcp服务器和透传模式。设备连接tcp后关闭wifi后没有断开tcp连接
服务器·网络·tcp/ip
rustfs5 分钟前
使用 podman 容器化安装 RustFS 详细指南
docker·rust·podman
优选资源分享6 分钟前
开源免费 Linux 服务器管理工具 Server Box v1.0.1297
linux·服务器·开源
颢珂智库Haokir Insights8 分钟前
宝塔面板安装教程(新手完整指南)
linux·运维·服务器
晨非辰12 分钟前
Linux文件操作实战:压缩/传输/计算10分钟速成,掌握核心命令组合与Shell内核交互秘籍
linux·运维·服务器·c++·人工智能·python·交互
代码AC不AC12 分钟前
【Linux】环境变量
linux·环境变量·命令行参数
Herry_64428082517 分钟前
docker构建前后端镜像配置说明
docker·docker构建镜像
努力努力再努力wz1 小时前
【Linux网络系列】:JSON+HTTP,用C++手搓一个web计算器服务器!
java·linux·运维·服务器·c语言·数据结构·c++
物理与数学9 小时前
linux 内存分布
linux·linux内核
东城绝神10 小时前
《Linux运维总结:基于ARM64+X86_64架构使用docker-compose一键离线部署MySQL8.0.43 NDB Cluster容器版集群》
linux·运维·mysql·架构·高可用·ndb cluster