策略说明
为了提高消息队列 RabbitMQ 集群的可靠性和容错能力,在用户新建 RabbitMQ 集群或者新建 Vhost 时(该集群节点数至少为3),为用户提供开启“默认镜像队列”的选项。此镜像队列可以在 RabbitMQ 集群中的多个节点上复制队列中的消息,确保在某个节点发生故障时,队列中的消息不会丢失。
以下是消息队列 RabbitMQ 为用户提供的“默认镜像队列”策略参数详细说明:
参数名 | 配置参数 | 参数说明 |
Name | pay-mirror-policy | 策略名称,用于标识和引用该策略。 |
Pattern | .* | 策略的匹配模式,采用正则表达式语法。表示匹配任意字符,表示匹配前面的字符零次或多次,所以 .* 表示匹配任意名称的队列。 |
Apply to | Queues | 策略的应用对象,设置为 Queues 表示策略应用于队列。 |
Priority | 0 | 策略的优先级。如果一个队列匹配多个策略,那么优先级高的策略将会被应用,0 表示最低优先级。 |
ha-mode | exactly | 镜像队列的复制模式。 exactly:表示队列的消息会被复制到指定数量的节点 all:表示队列的消息会被复制到所有节点。 选择 exactly 可以在保证可用性的同时,减少网络和存储的开销,提高性能。 |
ha-params | 3 | 镜像队列的复制参数。当 ha-mode 设置为 exactly 时,这里需要设置复制的节点数量。默认设置为3,即使将来扩展到5个节点,性能仍然可以保持在一个较好的水平。 |
ha-promote-on-failure | always | 节点故障时的镜像队列提升策略。always 表示无论节点故障的原因如何,都会将镜像队列提升为主队列。when-synced 表示只有当节点故障后重新同步时,才会将镜像队列提升为主队列。默认设置为 always,以确保在任何故障情况下都能保持服务的可用性。 |
ha-promote-on-shutdown | when-synced | 节点正常关闭时的镜像队列提升策略。 always:表示无论节点关闭的原因如何,都会将镜像队列提升为主队列。 when-synced:表示只有当节点关闭后重新同步时,才会将镜像队列提升为主队列。 默认设置为 when-synced,以避免不必要的提升操作。 |
ha-sync-mode | manual | 镜像队列的同步模式。 automatic:表示在节点启动或重新连接到集群时,自动将镜像队列与主队列同步。 manual:表示需要手动触发同步操作,将镜像队列与主队列同步。 默认设置为manual,以避免堆积消息时自动同步影响集群性能。 |
通过配置默认的镜像队列策略,可以在保证 RabbitMQ 集群可靠性的同时,优化性能和资源利用。用户可以根据自己的需求和场景,进一步调整这些参数,也可以删除并重新新建策略。
操作步骤
开启默认镜像队列
1. 新建集群时开启镜像队列:集群购买页 > 其他配置 > 开启镜像队列。
2. 新建 Vhost 时开启镜像队列:集群列表 > Vhost > 新建 Vhost > 开启镜像队列。
限制
消息队列 RabbitMQ 只允许3个或以上节点的集群开启“默认镜像队列”,主要是为了确保集群的高可用性和容错能力。在一个拥有3个或更多节点的集群中,镜像队列可以在多个节点上复制消息,这样既可以分担每个节点的负载,提高性能,又可以在某个节点发生故障时保证服务的正常运行。同时,这也提供了更多的灵活性,允许我们根据实际需求灵活配置镜像队列的参数。因此,这个限制是为了提供更稳定、更可靠的服务。