Followup on MariaDB handling fixes

This fixes issues reported by Mark:
- possible failure with 4-node cluster (however unlikely)
- failure to stop all nodes from progressing when conditions are
  not valid (due to: "any_errors_fatal: False")

Change-Id: Ib6995bf4c99202c9813859b3d9e2f420448f0445
This commit is contained in:
Radosław Piliszek 2020-01-28 09:40:21 +01:00
parent 4d0c442b88
commit 1ea029a91d
2 changed files with 23 additions and 12 deletions

View File

@ -68,13 +68,14 @@
when: when:
- groups.mariadb_port_alive_True is defined - groups.mariadb_port_alive_True is defined
- inventory_hostname in groups.mariadb_port_alive_True - inventory_hostname in groups.mariadb_port_alive_True
- groups.mariadb_port_alive_True.index(inventory_hostname) % 3 == item - groups.mariadb_port_alive_True.index(inventory_hostname) % 4 == item
- kolla_action != "config" - kolla_action != "config"
listen: restart mariadb listen: restart mariadb
loop: loop:
- 0 - 0
- 1 - 1
- 2 - 2
- 3
- name: Start MariaDB on new nodes - name: Start MariaDB on new nodes
include_tasks: 'restart_services.yml' include_tasks: 'restart_services.yml'

View File

@ -30,6 +30,15 @@
group_by: group_by:
key: mariadb_port_alive_{{ check_mariadb_port_liveness is success }} key: mariadb_port_alive_{{ check_mariadb_port_liveness is success }}
- name: Fail on existing but stopped cluster
fail:
msg: MariaDB cluster exists but is stopped. Please start it using kolla-ansible mariadb_recovery
when:
# NOTE(yoctozepto): we allow single-node cluster to start
- groups['mariadb'] | length > 1
- mariadb_cluster_exists
- groups.mariadb_port_alive_True is not defined
- block: - block:
- name: Check MariaDB service WSREP sync status - name: Check MariaDB service WSREP sync status
become: true become: true
@ -48,18 +57,19 @@
- name: Extract MariaDB service WSREP sync status - name: Extract MariaDB service WSREP sync status
set_fact: set_fact:
mariadb_sync_status: "{{ check_mariadb_sync_status.stdout.split('\t')[1] }}" mariadb_sync_status: "{{ check_mariadb_sync_status.stdout.split('\t')[1] }}"
- name: Divide hosts by their MariaDB service WSREP sync status
group_by:
key: mariadb_sync_status_{{ mariadb_sync_status }}
- name: Fail when MariaDB service is not synced
fail:
msg: MariaDB service is not synced. Please wait for WSREP sync before proceeding.
when:
- groups.mariadb_sync_status_Synced is not defined or
inventory_hostname not in groups.mariadb_sync_status_Synced
when: when:
- groups.mariadb_port_alive_True is defined - groups.mariadb_port_alive_True is defined
- inventory_hostname in groups.mariadb_port_alive_True - inventory_hostname in groups.mariadb_port_alive_True
- name: Divide hosts by their MariaDB service WSREP sync status
group_by:
key: mariadb_sync_status_{{ mariadb_sync_status | default('NA') }}
- name: Fail when MariaDB services are not synced across the whole cluster
fail:
msg: MariaDB cluster is not synced. Please wait for WSREP sync before proceeding.
when:
- groups.mariadb_port_alive_True is defined
- groups.mariadb_sync_status_Synced is not defined or
groups.mariadb_port_alive_True | sort != groups.mariadb_sync_status_Synced | sort
when: not mariadb_recover | default(False) when: not mariadb_recover | default(False)