80a32c3c74
This patch is roughly an adaptation of Ia6fc9011ee6f5461f40a1307b72709d769814a79 for cinder. During an upgrade, cinder pins the version of RPC calls to the minimum seen across all services. This ensures that old services do not receive data they cannot handle. After the upgrade is complete, all cinder services are supposed to be reloaded to cause them to check again the RPC versions of services and use the new latest version which should now be supported by all running services. There is a second issue in that it takes some time for the upgraded services to update the cinder services database table with their new version. We need to wait until all cinder services have done this before the restart is performed, otherwise the RPC version cap will remain in place. There is currently no interface in cinder available for checking these versions, so as a workaround we use a configurable delay with a default duration of 30 seconds, as we do for nova. This change restarts all cinder services after an upgrade, after a 30 second delay. Closes-Bug: #1954932 Related-Bug: #1833069 Change-Id: I9164dc589386d2c2d4daf1bf84061b806ba9988d
37 lines
953 B
YAML
37 lines
953 B
YAML
---
|
|
# NOTE (duonghq): I break config into 2 phases to prevent new version
|
|
# of service start if node or process in node crash accidentally.
|
|
- include_tasks: config.yml
|
|
when: inventory_hostname == groups["cinder-api"][0]
|
|
|
|
- import_tasks: bootstrap_service.yml
|
|
|
|
- import_tasks: config.yml
|
|
|
|
- import_tasks: check-containers.yml
|
|
|
|
- name: Flush handlers
|
|
meta: flush_handlers
|
|
|
|
- import_tasks: reload.yml
|
|
|
|
- name: Running Cinder online schema migration
|
|
vars:
|
|
cinder_api: "{{ cinder_services['cinder-api'] }}"
|
|
become: true
|
|
kolla_docker:
|
|
action: "start_container"
|
|
common_options: "{{ docker_common_options }}"
|
|
detach: False
|
|
environment:
|
|
KOLLA_OSM:
|
|
KOLLA_CONFIG_STRATEGY: "{{ config_strategy }}"
|
|
image: "{{ cinder_api.image }}"
|
|
labels:
|
|
BOOTSTRAP:
|
|
name: "bootstrap_cinder"
|
|
restart_policy: no
|
|
volumes: "{{ cinder_api.volumes }}"
|
|
run_once: True
|
|
delegate_to: "{{ groups[cinder_api.group][0] }}"
|