分布式集群
Coolpy7分布式技术,支持多个Coolpy7 Core提供跨数据中心(多活)模式组建群集,支持群集零手动维护(基于Gossip分布式协议作为群集节点状态维护)。Coolpy7从版本号V7.3.2.3开始支持本功能。请到Coolpy7之github项目release下载相关版本https://github.com/Coolpy7/Coolpy7/releases。也可以通过docker安装。
Last updated
Coolpy7分布式技术,支持多个Coolpy7 Core提供跨数据中心(多活)模式组建群集,支持群集零手动维护(基于Gossip分布式协议作为群集节点状态维护)。Coolpy7从版本号V7.3.2.3开始支持本功能。请到Coolpy7之github项目release下载相关版本https://github.com/Coolpy7/Coolpy7/releases。也可以通过docker安装。
Last updated
Coolpy7消息服务器集群基于Gossip协议作为服务发现,基于UDP作为集群节点间消息转发通信的分布式设计,集群原理可简述为下述几条规则:
所有节点独立维护自有的身份验证、订阅、取消订阅事件处理
集群之间只会转发PUBLISH消息,并且消息体少于64K的消息
节点内组播消息不被转发,只在当前节点有效
集群之间不保证消息不丢失,只转发消息到所有在线节点,转发会忽略离线节点
客户端连接某一个节点后,将会收到来自其他节点给它的消息(于订阅的主题)
Coolpy7集群架构图
消息分发流
假设部署三台服务器 192.168.1.100, 192.168.1.101, 192.168.1.102 上部署集群:
节点名
IP
node1@192.168.1.100
192.168.1.100
node2@192.168.1.101
192.168.1.101
node3@192.168.1.102
192.168.1.102
1.节点名不允许重复,否则群集将无法自动维护集群状态
2.当使用外网IP或域名进行跨数据中心集群时,通过“节点名@IP地址或域名”进行指定IP设置。
打印消息提示,群集使用UDP的7946端口进行集群服务发现,UDP的7947端口进行消息同步服务。
如需自定义端口可通过启动参数
-crp int 集群发现端口(UDP) (default 7946)
-csp int 集群同步端口(UDP) (default 7947)
至此集群搭建完毕,现在即可通过MQTT客户端工具(MQTTLens)等进行相关集群功能测试。可从A节点连接的客户端推送消息,然后B,C节点的客户端如果订阅了相同主题将会收到相关跨节点消息。
集群自动恢复功能说明:
节点网络异常离线各节点会发现ping包没有响应,
随后邀请其他在线节点向异常节点发起ping测试,
如经过三轮周期没有得到异常节点响应
当前节点设置该节点为离线状态
移出在线节点列表。
异常节点再次上线
所有在线节点收到状态信号
所有节点设置该节点为在线
添加该节点到在线列表
消息桥接是为CP7集群各节点间的消息同步提供可配置性的相关功能。
通过启动参数进行配置相关桥接主题指定主题消息过滤桥接。默认参数值以 # 号表示全量消息桥接。需指定特定主题是以半角豆号隔开多个主题,如:aaa/#,bbb/#
Coolpy7使用UDP协议进行集群节点状态信号和消息同步通信,所以需要开启相关UDP端口防火墙
最新版本docker镜像已更新到latest标签版本下,docker hub地址:https://hub.docker.com/r/coolpy7/coolpy7_core ,docker相关部署方式请参阅本手册相关章节。Docker部署(Windows运行CP7)/kai-shi-shi-yong/docker-bu-shu-windows-yun-hang-cp7