Improve RabbitMQ performance by reducing ha replicas

Currently we do not follow the RabbitMQ advice on replicas here:
https://www.rabbitmq.com/ha.html#replication-factor

Here we reduce the number of replicas to n // 2 + 1 as advised
above. The hope it this helps speed up recovery from rabbit
issues.

Related-Bug: #1954925
Change-Id: Ib6bcb26c499c9884faa4a0cd51abaec00cacb096
This commit is contained in:
John Garbutt 2021-12-17 17:34:44 +00:00 committed by Matt Crees
parent e13072a98d
commit 6cf22b0cb1
2 changed files with 25 additions and 1 deletions

View File

@ -89,10 +89,16 @@ rabbitmq_cluster_partition_handling: "pause_minority"
# More details see: # More details see:
# https://www.rabbitmq.com/ha.html#promoting-unsynchronised-mirrors # https://www.rabbitmq.com/ha.html#promoting-unsynchronised-mirrors
rabbitmq_ha_promote_on_shutdown: rabbitmq_ha_promote_on_shutdown:
# The number of rabbitmq replicas should follow this advice:
# https://www.rabbitmq.com/ha.html#replication-factor
# This means, if you have three rabbit nodes, we request two
# replicas of all queues and exchanges.
# Note: this assumes an odd number of rabbitmq nodes.
# If no replica count is specified, replicates across all nodes with definition # If no replica count is specified, replicates across all nodes with definition
# "ha-mode":"all". Otherwise, uses # "ha-mode":"all". Otherwise, uses
# "ha-mode":"exactly","ha-params":{{ rabbitmq_ha_replica_count | int }} # "ha-mode":"exactly","ha-params":{{ rabbitmq_ha_replica_count | int }}
rabbitmq_ha_replica_count: rabbitmq_server_count: "{{ groups[role_rabbitmq_groups] | length }}"
rabbitmq_ha_replica_count: "{{ (rabbitmq_server_count | int // 2 + 1) }}"
rabbitmq_extra_config: {} rabbitmq_extra_config: {}
#################### ####################

View File

@ -0,0 +1,18 @@
---
upgrade:
- |
RabbitMQ replica count has changed from n to (n//2+1) where n is the number
of RabbitMQ nodes. That is, for a 3 node clusters, we request exactly 2
replicas, for a 1 node cluster, we request 1 replica, and for a 5 node
cluster, we request 3 replicas. This only has an effect if
`om_enable_rabbitmq_high_availability` is set to `True`, otherwise queues
are not replicated. The number of mirrored queues is not changed
automatically, and instead requires the queues to be recreated (for
example, by restarting RabbitMQ).
This follows the good practice advice here:
https://www.rabbitmq.com/ha.html#replication-factor
A major motivation is to reduce the load on RabbitMQ in larger
deployments. It is hoped, the improved performance should also
help rabbitmq recover more quickly from cluster issues.
Note that the contents of the RabbitMQ definitions.json are now changed,
meaning RabbitMQ containers will be restarted on next deploy/upgrade.