Remove non-containerized pacemaker resources on upgrade

Adds upgrade_tasks to remove the pacemaker resources using the
ansible-pacemaker module.

Resources are disabled and removed in step2 (called only on
bootstrap node) and then the cluster stop is moved to step3

The existing systemd/service call is kept but only to disable
services after they are disabled/deleted from the cluster.

Related-Bug: 1701485
Co-Authored-By: Damien Ciabrini <dciabrin@redhat.com>
Change-Id: Ia597d240ea5834c50a8f6c4fac0b6ed417b8535c
This commit is contained in:
marios 2017-07-04 16:52:26 +03:00
parent a34955d451
commit cdc3477b77
8 changed files with 141 additions and 31 deletions

View File

@ -139,6 +139,27 @@ outputs:
- /var/lib/cinder - /var/lib/cinder
- /var/log/containers/cinder - /var/log/containers/cinder
upgrade_tasks: upgrade_tasks:
- name: Stop and disable cinder_backup service - name: get bootstrap nodeid
tags: common
command: hiera -c /etc/puppet/hiera.yaml bootstrap_nodeid
register: bootstrap_node
- name: set is_bootstrap_node fact
tags: common
set_fact: is_bootstrap_node={{bootstrap_node.stdout|lower == ansible_hostname|lower}}
- name: Disable the openstack-cinder-backup cluster resource
tags: step2 tags: step2
service: name=openstack-cinder-backup state=stopped enabled=no pacemaker_resource:
resource: openstack-cinder-backup
state: disable
wait_for_resource: true
when: is_bootstrap_node
- name: Delete the stopped openstack-cinder-backup cluster resource.
tags: step2
pacemaker_resource:
resource: openstack-cinder-backup
state: delete
wait_for_resource: true
when: is_bootstrap_node
- name: Disable cinder_backup service
tags: step2
service: name=openstack-cinder-backup enabled=no

View File

@ -157,6 +157,30 @@ outputs:
executable: /bin/bash executable: /bin/bash
creates: /dev/loop2 creates: /dev/loop2
upgrade_tasks: upgrade_tasks:
- name: Stop and disable cinder_volume service - name: get bootstrap nodeid
tags: common
command: hiera -c /etc/puppet/hiera.yaml bootstrap_nodeid
register: bootstrap_node
- name: set is_bootstrap_node fact
tags: common
set_fact: is_bootstrap_node={{bootstrap_node.stdout|lower == ansible_hostname|lower}}
- name: Disable the openstack-cinder-volume cluster resource
tags: step2 tags: step2
service: name=openstack-cinder-volume state=stopped enabled=no pacemaker_resource:
resource: openstack-cinder-volume
state: disable
wait_for_resource: true
when: is_bootstrap_node
- name: Delete the stopped openstack-cinder-volume cluster resource.
tags: step2
pacemaker_resource:
resource: openstack-cinder-volume
state: delete
wait_for_resource: true
when: is_bootstrap_node
- name: Disable cinder_volume service from boot
tags: step2
service: name=openstack-cinder-volume enabled=no

View File

@ -164,6 +164,27 @@ outputs:
path: /var/lib/mysql path: /var/lib/mysql
state: directory state: directory
upgrade_tasks: upgrade_tasks:
- name: Stop and disable mysql service - name: get bootstrap nodeid
tags: common
command: hiera -c /etc/puppet/hiera.yaml bootstrap_nodeid
register: bootstrap_node
- name: set is_bootstrap_node fact
tags: common
set_fact: is_bootstrap_node={{bootstrap_node.stdout|lower == ansible_hostname|lower}}
- name: Disable the galera cluster resource
tags: step2 tags: step2
service: name=mariadb state=stopped enabled=no pacemaker_resource:
resource: galera
state: disable
wait_for_resource: true
when: is_bootstrap_node
- name: Delete the stopped galera cluster resource.
tags: step2
pacemaker_resource:
resource: galera
state: delete
wait_for_resource: true
when: is_bootstrap_node
- name: Disable mysql service
tags: step2
service: name=mariadb enabled=no

View File

@ -139,6 +139,27 @@ outputs:
path: /var/lib/redis path: /var/lib/redis
state: directory state: directory
upgrade_tasks: upgrade_tasks:
- name: Stop and disable redis service - name: get bootstrap nodeid
tags: common
command: hiera -c /etc/puppet/hiera.yaml bootstrap_nodeid
register: bootstrap_node
- name: set is_bootstrap_node fact
tags: common
set_fact: is_bootstrap_node={{bootstrap_node.stdout|lower == ansible_hostname|lower}}
- name: Disable the redis cluster resource
tags: step2 tags: step2
service: name=redis state=stopped enabled=no pacemaker_resource:
resource: {get_attr: [RedisBase, role_data, service_name]}
state: disable
wait_for_resource: true
when: is_bootstrap_node
- name: Delete the stopped redis cluster resource.
tags: step2
pacemaker_resource:
resource: {get_attr: [RedisBase, role_data, service_name]}
state: delete
wait_for_resource: true
when: is_bootstrap_node
- name: Disable redis service
tags: step2
service: name=redis enabled=no

View File

@ -137,3 +137,25 @@ outputs:
- /dev/shm:/dev/shm:rw - /dev/shm:/dev/shm:rw
metadata_settings: metadata_settings:
get_attr: [HAProxyBase, role_data, metadata_settings] get_attr: [HAProxyBase, role_data, metadata_settings]
upgrade_tasks:
- name: get bootstrap nodeid
tags: common
command: hiera -c /etc/puppet/hiera.yaml bootstrap_nodeid
register: bootstrap_node
- name: set is_bootstrap_node fact
tags: common
set_fact: is_bootstrap_node={{bootstrap_node.stdout|lower == ansible_hostname|lower}}
- name: Disable the haproxy cluster resource.
tags: step2
pacemaker_resource:
resource: {get_attr: [HAProxyBase, role_data, service_name]}
state: disable
wait_for_resource: true
when: is_bootstrap_node
- name: Delete the stopped haproxy cluster resource.
tags: step2
pacemaker_resource:
resource: {get_attr: [HAProxyBase, role_data, service_name]}
state: delete
wait_for_resource: true
when: is_bootstrap_node

View File

@ -157,6 +157,27 @@ outputs:
echo 'export ERL_EPMD_PORT=4370' >> /etc/rabbitmq/rabbitmq-env.conf echo 'export ERL_EPMD_PORT=4370' >> /etc/rabbitmq/rabbitmq-env.conf
for pid in $(pgrep epmd); do if [ "$(lsns -o NS -p $pid)" == "$(lsns -o NS -p 1)" ]; then kill $pid; break; fi; done for pid in $(pgrep epmd); do if [ "$(lsns -o NS -p $pid)" == "$(lsns -o NS -p 1)" ]; then kill $pid; break; fi; done
upgrade_tasks: upgrade_tasks:
- name: Stop and disable rabbitmq service - name: get bootstrap nodeid
tags: common
command: hiera -c /etc/puppet/hiera.yaml bootstrap_nodeid
register: bootstrap_node
- name: set is_bootstrap_node fact
tags: common
set_fact: is_bootstrap_node={{bootstrap_node.stdout|lower == ansible_hostname|lower}}
- name: Disable the rabbitmq cluster resource.
tags: step2 tags: step2
service: name=rabbitmq-server state=stopped enabled=no pacemaker_resource:
resource: {get_attr: [RabbitmqBase, role_data, service_name]}
state: disable
wait_for_resource: true
when: is_bootstrap_node
- name: Delete the stopped rabbitmq cluster resource.
tags: step2
pacemaker_resource:
resource: {get_attr: [RabbitmqBase, role_data, service_name]}
state: delete
wait_for_resource: true
when: is_bootstrap_node
- name: Disable rabbitmq service
tags: step2
service: name=rabbitmq-server enabled=no

View File

@ -3,9 +3,6 @@
# ...deploy..-e docker.yaml -e docker-ha.yaml # ...deploy..-e docker.yaml -e docker-ha.yaml
resource_registry: resource_registry:
# Pacemaker runs on the host # Pacemaker runs on the host
OS::TripleO::Tasks::ControllerPreConfig: ../extraconfig/tasks/pre_puppet_pacemaker.yaml
OS::TripleO::Tasks::ControllerPostConfig: ../extraconfig/tasks/post_puppet_pacemaker.yaml
OS::TripleO::Tasks::ControllerPostPuppetRestart: ../extraconfig/tasks/post_puppet_pacemaker_restart.yaml
OS::TripleO::Services::Pacemaker: ../puppet/services/pacemaker.yaml OS::TripleO::Services::Pacemaker: ../puppet/services/pacemaker.yaml
OS::TripleO::Services::PacemakerRemote: ../puppet/services/pacemaker_remote.yaml OS::TripleO::Services::PacemakerRemote: ../puppet/services/pacemaker_remote.yaml

View File

@ -105,11 +105,6 @@ parameters:
description: Whether to deploy a LoadBalancer on the Controller description: Whether to deploy a LoadBalancer on the Controller
type: boolean type: boolean
PacemakerResources:
type: comma_delimited_list
description: List of resources managed by pacemaker
default: ['rabbitmq', 'galera']
outputs: outputs:
role_data: role_data:
description: Role data for the Pacemaker role. description: Role data for the Pacemaker role.
@ -156,20 +151,8 @@ outputs:
async: 30 async: 30
poll: 4 poll: 4
- name: Stop pacemaker cluster - name: Stop pacemaker cluster
tags: step2 tags: step3
pacemaker_cluster: state=offline pacemaker_cluster: state=offline
- name: Start pacemaker cluster - name: Start pacemaker cluster
tags: step4 tags: step4
pacemaker_cluster: state=online pacemaker_cluster: state=online
- name: Check pacemaker resource
tags: step4
pacemaker_is_active:
resource: "{{ item }}"
max_wait: 500
with_items: {get_param: PacemakerResources}
- name: Check pacemaker haproxy resource
tags: step4
pacemaker_is_active:
resource: haproxy
max_wait: 500
when: {get_param: EnableLoadBalancer}