EMQX 集群节点数据转发

EMQX 分布式集群设计

emqx 分布式集群解决的问题是将客户端连接分到不同的节点上,从而获得最大的连接数和并发量,但是也带来了新的问题:订阅者和发布者可能不在同一个节点上,发布者的消息需要进行中转才能到达订阅者。

于是 emqx 设计了一套数据路由中转机制,其中主要使用了订阅表、路由表、主题树。三者搭配实现了数据的路由。

订阅表

说明: 即 topic 和 订阅客户端 的对应关系。该订阅表记录只存在于订阅者所在的 EMQX 节点上。

目的:便于根据 topic 获取到 到订阅者,从而向订阅者发送消息。

路由表

说明:维护了节点和 topic 的对应关系。同一集群中的所有节点将都维护了主题到节点的映射表。

目的:当消息到达某个节点时,可以根据 topic 查找到订阅对应 topic 的客户端连接在那个节点上,从而将消息路由到该节点。

主题树

说明:EMQX 会维护 主题树。

目的:用于匹配多个主题。当发布者发布主题时,从主题树上获取到匹配的主题

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在 Docker 中部署 EMQ X 集群,可以使用 `docker run` 命令和 `emqx` 镜像。以下是一个简单的示例,演示如何使用 `docker run` 命令在三个节点上运行 EMQ X: ``` # 启动第一个节点 docker run -d --name emqx1 \ -p 1883:1883 -p 8083:8083 -p 8883:8883 \ -e EMQX_LISTENER__TCP__EXTERNAL=0.0.0.0:1883 \ -e EMQX_LOADED_PLUGINS="emqx_recon,emqx_retainer,emqx_management" \ -e EMQX_CLUSTER__DISCOVERY="static" \ -e EMQX_CLUSTER__STATIC__SEEDS="emqx2@172.17.0.3,emqx3@172.17.0.4" \ -e EMQX_NODE__NAME="emqx1" \ -e EMQX_NODE__MACHINE="emqx1" \ emqx/emqx:latest # 启动第二个节点 docker run -d --name emqx2 \ -p 1884:1883 -p 8084:8083 -p 8884:8883 \ -e EMQX_LISTENER__TCP__EXTERNAL=0.0.0.0:1883 \ -e EMQX_LOADED_PLUGINS="emqx_recon,emqx_retainer,emqx_management" \ -e EMQX_CLUSTER__DISCOVERY="static" \ -e EMQX_CLUSTER__STATIC__SEEDS="emqx1@172.17.0.2,emqx3@172.17.0.4" \ -e EMQX_NODE__NAME="emqx2" \ -e EMQX_NODE__MACHINE="emqx2" \ emqx/emqx:latest # 启动第三个节点 docker run -d --name emqx3 \ -p 1885:1883 -p 8085:8083 -p 8885:8883 \ -e EMQX_LISTENER__TCP__EXTERNAL=0.0.0.0:1883 \ -e EMQX_LOADED_PLUGINS="emqx_recon,emqx_retainer,emqx_management" \ -e EMQX_CLUSTER__DISCOVERY="static" \ -e EMQX_CLUSTER__STATIC__SEEDS="emqx1@172.17.0.2,emqx2@172.17.0.3" \ -e EMQX_NODE__NAME="emqx3" \ -e EMQX_NODE__MACHINE="emqx3" \ emqx/emqx:latest ``` 上面的命令会在三个容器中分别启动 EMQ X 节点,并将三个节点加入到同一个集群中。我们在每个容器中使用不同的节点名称、集群名称和节点地址等参数,以确保 EMQ X 能够正确地运行和通信。其中每个节点的 `EMQX_CLUSTER__STATIC__SEEDS` 参数需要设置为其他两个节点的地址,这样才能够互相发现和加入到集群中。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值