rabbitmq 同步策略_RabbitMQ 集群之镜像同步

本文介绍了RabbitMQ集群中如何实现queue的镜像同步,以确保高可用性和高可靠性。默认情况下,queue仅存在于单个节点,而通过设置镜像策略(如ha-all),可以实现在所有节点上的同步。文章详细讲解了如何配置同步策略,包括同步方式、参数设置,以及代码示例展示如何在节点故障时自动恢复连接和工作进程。
摘要由CSDN通过智能技术生成

在上个博文中讲到了如果做集群,那么集群是成功了,但是queue是如何存放的呢?消息又是怎么同步呢。

默认的,也就是什么也不配置,直接在某个节点中添加一个queue,那么它仅仅是属于这个节点的。其它节点有的只是它的影子。所以像断线重连、操作恢复是无法做到的,实验证明确实是这样的。声明queue的节点关闭那么是无法再进行发布消息与消费的。这自然失去了集群的意义

所以default模式一般是不会进行使用的,我们的选择是 镜像节点

queue mirror 也就是说,也就是 会有一个 master 对应零个或多个 slave

也可以说成主从复制,每个节点都有着相同的数据,某个节点挂掉了,另一个可以立即顶上

官方的文档也可以看到,镜像的配置是通过 policy 策略的方式

我们有三种同步的方式,一般来说  all 是我们的最佳选择

all 所有的节点都将被同步

exactly 指定个数的节点被同步

nodes 指定的名称的节点被同步

一个简单的示例,下面使用的是ha-all 是我们的策略名称,后面的是^ha\. 则是一个正则,queue名满足这个规则的,将被做镜像。方式是所有的节点都被同步

这里需要说明的是 策略 可以被应用到exchange与queue上面,也可以选择只被应用到哪个上面,下面的命令则是exchange与queue都被应用到了

rabbitmqctl set_policy ha-all "^ha\." "{"

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值