
The current rolling upgrade implementation relies on the role to orchestrate the rolling upgrade. When the role is executed using playbook serialisation, the db sync contract is executed before all hosts are upgraded, potentially resulting in data corruption. This patch returns the role to the simpler, best practice model of expecting that the role is applied to a single host and that the playbook handles orchestration. This method can be used with any form of serialisation. Depends-On: Ie90cdcbf9e73082a2074c8832b7490d188e178af Change-Id: I5650f16b9a115bd392012b743788057a94d09226
81 lines
2.9 KiB
YAML
81 lines
2.9 KiB
YAML
---
|
|
# Copyright 2014, Rackspace US, Inc.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
|
|
- name: Check current state of Keystone DB
|
|
command: "{{ keystone_bin }}/keystone-manage db_sync --check"
|
|
register: keystone_db_sync_check
|
|
failed_when: "keystone_db_sync_check.rc == 1"
|
|
changed_when: "keystone_db_sync_check.rc not in [2, 3, 4]"
|
|
|
|
- name: Set the db sync local facts
|
|
ini_file:
|
|
dest: "/etc/ansible/facts.d/openstack_ansible.fact"
|
|
section: keystone
|
|
option: "{{ item.name }}"
|
|
value: "{{ item.state }}"
|
|
with_items:
|
|
- name: "need_db_expand"
|
|
state: "{{ (keystone_db_sync_check.rc | int == 2) | bool }}"
|
|
- name: "need_db_migrate"
|
|
state: "{{ (keystone_db_sync_check.rc | int in [2, 3] ) | bool }}"
|
|
- name: "need_db_contract"
|
|
state: "{{ (keystone_db_sync_check.rc | int in [2, 3, 4]) | bool }}"
|
|
|
|
- name: Refresh local facts
|
|
setup:
|
|
filter: ansible_local
|
|
gather_subset: "!all"
|
|
tags:
|
|
- keystone-config
|
|
|
|
- name: Ensure keystone service is stopped
|
|
service:
|
|
name: "{{ item }}"
|
|
state: stopped
|
|
register: keystone_stop
|
|
failed_when:
|
|
- "keystone_stop.msg is defined"
|
|
- "'no service or tool' not in keystone_stop.msg"
|
|
- "'systemd could not find' not in keystone_stop.msg"
|
|
- "'Could not find the requested service' not in keystone_stop.msg"
|
|
with_items:
|
|
- "{{ keystone_wsgi_program_names }}"
|
|
- "{{ keystone_system_service_name }}"
|
|
when:
|
|
- "(ansible_local['openstack_ansible']['keystone']['need_db_expand'] | bool) or
|
|
(ansible_local['openstack_ansible']['keystone']['need_db_migrate'] | bool)"
|
|
|
|
- name: Perform a Keystone DB sync expand
|
|
command: "{{ keystone_bin }}/keystone-manage db_sync --expand"
|
|
become: yes
|
|
become_user: "{{ keystone_system_user_name }}"
|
|
when:
|
|
- "ansible_local['openstack_ansible']['keystone']['need_db_expand'] | bool"
|
|
|
|
- name: Perform a Keystone DB sync migrate
|
|
command: "{{ keystone_bin }}/keystone-manage db_sync --migrate"
|
|
become: yes
|
|
become_user: "{{ keystone_system_user_name }}"
|
|
when:
|
|
- "ansible_local['openstack_ansible']['keystone']['need_db_migrate'] | bool"
|
|
|
|
- name: Perform a Keystone DB sync contract
|
|
command: "{{ keystone_bin }}/keystone-manage db_sync --contract"
|
|
become: yes
|
|
become_user: "{{ keystone_system_user_name }}"
|
|
when:
|
|
- "(keystone_all_software_updated | default('no')) | bool"
|
|
- "ansible_local['openstack_ansible']['keystone']['need_db_contract'] | bool"
|