Add precheck for RabbitMQ quorum queues
Adds a precheck to fail if non-quorum queues are found in RabbitMQ. Currently excludes fanout and reply queues, pending support in oslo.messaging [1]. [1]: https://review.opendev.org/c/openstack/oslo.messaging/+/888479 Closes-Bug: #2045887 Change-Id: Ibafdcd58618d97251a3405ef9332022d4d930e2b
This commit is contained in:
parent
7a29abb590
commit
61f84e3beb
@ -223,3 +223,33 @@
|
|||||||
- container_facts['rabbitmq'] is defined
|
- container_facts['rabbitmq'] is defined
|
||||||
- om_enable_rabbitmq_high_availability | bool
|
- om_enable_rabbitmq_high_availability | bool
|
||||||
tags: rabbitmq-ha-precheck
|
tags: rabbitmq-ha-precheck
|
||||||
|
|
||||||
|
- block:
|
||||||
|
- name: List RabbitMQ queues
|
||||||
|
become: true
|
||||||
|
shell:
|
||||||
|
# TODO(mattcrees): remove ``| egrep -v '(fanout|reply)'`` once https://review.opendev.org/c/openstack/oslo.messaging/+/888479 is merged.
|
||||||
|
cmd: "{{ kolla_container_engine }} exec rabbitmq rabbitmqctl list_queues --silent name type | egrep -v '(fanout|reply)' | awk '{ print $NF }'"
|
||||||
|
register: rabbitmq_queues
|
||||||
|
changed_when: false
|
||||||
|
check_mode: false
|
||||||
|
|
||||||
|
- name: Filter RabbitMQ queue types
|
||||||
|
set_fact:
|
||||||
|
rabbitmq_queue_types: "{{ rabbitmq_queues.stdout | split | unique }}"
|
||||||
|
|
||||||
|
- name: Check if RabbitMQ quorum queues need to be configured
|
||||||
|
assert:
|
||||||
|
that: "{{ (rabbitmq_queue_types | length == 1) and (rabbitmq_queue_types | first == 'quorum') }}"
|
||||||
|
fail_msg: >
|
||||||
|
om_enable_rabbitmq_quorum_queues is True but non-quorum queues have been found.
|
||||||
|
Currently the procedure to migrate to quorum queues is manual.
|
||||||
|
Please follow the process described here: https://docs.openstack.org/kolla-ansible/latest/reference/message-queues/rabbitmq.html#high-availability.
|
||||||
|
Note that this process may take several hours on larger systems, and may cause a degredation in performance at large scale.
|
||||||
|
If you do not wish to enable this feature, set om_enable_rabbitmq_quorum_queues to False.
|
||||||
|
|
||||||
|
run_once: true
|
||||||
|
when:
|
||||||
|
- container_facts['rabbitmq'] is defined
|
||||||
|
- om_enable_rabbitmq_quorum_queues | bool
|
||||||
|
tags: rabbitmq-ha-precheck
|
||||||
|
@ -0,0 +1,9 @@
|
|||||||
|
---
|
||||||
|
fixes:
|
||||||
|
- |
|
||||||
|
A precheck has been added to catch when
|
||||||
|
``om_enable_rabbitmq_quorum_queues`` is set to ``True``, but quorum queues
|
||||||
|
have not been configured on all appropriate queues. A manual migration is
|
||||||
|
required, see here for details:
|
||||||
|
https://docs.openstack.org/kolla-ansible/latest/reference/message-queues/rabbitmq.html#high-availability
|
||||||
|
`LP#2045887 <https://launchpad.net/bugs/2045887>`__
|
@ -12,11 +12,10 @@ function upgrade {
|
|||||||
|
|
||||||
source $KOLLA_ANSIBLE_VENV_PATH/bin/activate
|
source $KOLLA_ANSIBLE_VENV_PATH/bin/activate
|
||||||
|
|
||||||
kolla-ansible -i ${RAW_INVENTORY} -vvv prechecks &> /tmp/logs/ansible/upgrade-prechecks
|
kolla-ansible -i ${RAW_INVENTORY} -vvv prechecks --skip-tags rabbitmq-ha-precheck &> /tmp/logs/ansible/upgrade-prechecks
|
||||||
|
|
||||||
# NOTE(mattcrees): As om_enable_rabbitmq_quorum_queues now defaults to
|
# NOTE(mattcrees): As om_enable_rabbitmq_quorum_queues now defaults to
|
||||||
# true in Bobcat, we need to perform a migration to durable queues.
|
# true in Bobcat, we need to perform a migration to durable queues.
|
||||||
# TODO(mattcrees): Remove these steps in Caracal.
|
|
||||||
SERVICE_TAGS="heat,keystone,neutron,nova"
|
SERVICE_TAGS="heat,keystone,neutron,nova"
|
||||||
if [[ $SCENARIO == "zun" ]] || [[ $SCENARIO == "cephadm" ]]; then
|
if [[ $SCENARIO == "zun" ]] || [[ $SCENARIO == "cephadm" ]]; then
|
||||||
SERVICE_TAGS+=",cinder"
|
SERVICE_TAGS+=",cinder"
|
||||||
@ -44,6 +43,9 @@ function upgrade {
|
|||||||
kolla-ansible -i ${RAW_INVENTORY} -vvv pull &> /tmp/logs/ansible/pull-upgrade
|
kolla-ansible -i ${RAW_INVENTORY} -vvv pull &> /tmp/logs/ansible/pull-upgrade
|
||||||
kolla-ansible -i ${RAW_INVENTORY} -vvv upgrade &> /tmp/logs/ansible/upgrade
|
kolla-ansible -i ${RAW_INVENTORY} -vvv upgrade &> /tmp/logs/ansible/upgrade
|
||||||
|
|
||||||
|
# Check that all appropriate RabbitMQ queues are now quorum queues.
|
||||||
|
kolla-ansible -i ${RAW_INVENTORY} -vvv prechecks --tags rabbitmq-ha-precheck &> /tmp/logs/ansible/rabbitmq-ha-precheck
|
||||||
|
|
||||||
kolla-ansible -i ${RAW_INVENTORY} -vvv post-deploy &> /tmp/logs/ansible/upgrade-post-deploy
|
kolla-ansible -i ${RAW_INVENTORY} -vvv post-deploy &> /tmp/logs/ansible/upgrade-post-deploy
|
||||||
|
|
||||||
kolla-ansible -i ${RAW_INVENTORY} -vvv validate-config &> /tmp/logs/ansible/validate-config
|
kolla-ansible -i ${RAW_INVENTORY} -vvv validate-config &> /tmp/logs/ansible/validate-config
|
||||||
|
Loading…
x
Reference in New Issue
Block a user