9b9bc21121
With update of ansible-lint to version >=6.0.0 a lot of new linters were added, that enabled by default. In order to comply with linter rules we're applying changes to the role. With that we also update metdata to reflect current state. Depends-On: https://review.opendev.org/c/openstack/ansible-role-systemd_service/+/888223 Change-Id: I730ae569f199fc8542a5a61beb149f459465d7e2
94 lines
4.1 KiB
YAML
94 lines
4.1 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: Synchronize the nova API DB schema
|
|
command: "{{ nova_bin }}/nova-manage api_db sync"
|
|
become: yes
|
|
become_user: "{{ nova_system_user_name }}"
|
|
changed_when: false
|
|
|
|
# This is idempotent and therefore safe for greenfield
|
|
# and brownfield installations.
|
|
- name: Create the cell0 mapping entry in the nova API DB
|
|
command: >-
|
|
{{ nova_bin }}/nova-manage cell_v2 map_cell0
|
|
--database_connection mysql+pymysql://{{ nova_api_galera_user }}:{{ nova_api_container_mysql_password }}@{{ nova_api_galera_address }}/{{
|
|
nova_cell0_database }}?charset=utf8{% if nova_galera_use_ssl | bool %}&ssl_ca={{ nova_galera_ssl_ca_cert }}{% endif %}
|
|
become: yes
|
|
become_user: "{{ nova_system_user_name }}"
|
|
changed_when: false
|
|
|
|
- name: Synchronize the nova DB schema
|
|
command: "{{ nova_bin }}/nova-manage db sync"
|
|
become: yes
|
|
become_user: "{{ nova_system_user_name }}"
|
|
changed_when: false
|
|
|
|
# We need to check for existance of the cell, since nova-manage cell_v2 create_cell
|
|
# might be not idempotent due to the bug https://bugs.launchpad.net/nova/+bug/1923899
|
|
- name: Get UUID of new Nova Cell
|
|
shell: "{{ nova_bin }}/nova-manage cell_v2 list_cells | grep ' {{ nova_cell1_name }} '"
|
|
become: yes
|
|
become_user: "{{ nova_system_user_name }}"
|
|
changed_when: false
|
|
failed_when: false
|
|
register: _cell_uuid
|
|
|
|
- name: Create the cell1 mapping entry in the nova API DB
|
|
command: >-
|
|
{{ nova_bin }}/nova-manage cell_v2 create_cell
|
|
--name {{ nova_cell1_name }}
|
|
--database_connection {scheme}://{username}:{password}@{hostname}:{port}/{path}?{query}
|
|
--transport-url {scheme}://{username}:{password}@{hostname}:{port}//{path}?{query}
|
|
become: yes
|
|
become_user: "{{ nova_system_user_name }}"
|
|
register: nova_cell1_create
|
|
# When upgrading, cell1 will already exist and nova-manage will
|
|
# give a return code of 2, so we therefore know that if the
|
|
# return code is:
|
|
# 0: the cell mapping record in the nova API database was
|
|
# successfully implemented (greenfield install)
|
|
# 2: the cell mapping record in the nova API database already
|
|
# exists (brownfield install). This is not working for templates
|
|
# because of the bug https://bugs.launchpad.net/nova/+bug/1923899
|
|
failed_when: "nova_cell1_create.rc not in [0, 2]"
|
|
changed_when: "nova_cell1_create.rc == 0"
|
|
when: "_cell_uuid.rc == 1"
|
|
|
|
# The nova-status upgrade check command is typically run after upgrading the
|
|
# controller services to new code, but is also OK to run for a greenfield
|
|
# install to verify everything is setup correctly. This must run after cell
|
|
# mapping setup and before actual service restart.
|
|
# https://docs.openstack.org/nova/latest/cli/nova-status.html
|
|
- name: Run nova-status upgrade check to validate a healthy configuration
|
|
command: "{{ nova_bin }}/nova-status upgrade check"
|
|
become: yes
|
|
become_user: "{{ nova_system_user_name }}"
|
|
register: nova_status_upgrade_check
|
|
until: nova_status_upgrade_check is success
|
|
retries: 8
|
|
delay: 15
|
|
# The nova-status upgrade check command has three standard return codes:
|
|
# 0: all checks were successful
|
|
# 1: warning: there might be some checks that require investigation, but
|
|
# generally will not block an automated install/upgrade; digging into
|
|
# warnings is useful for debugging post-install/upgrade issues
|
|
# 2: at least one check failed and must stop the install/upgrade because
|
|
# something was not setup properly
|
|
failed_when: "nova_status_upgrade_check.rc not in [0, 1]"
|
|
changed_when: false
|
|
when:
|
|
- "ansible_local['openstack_ansible']['nova']['need_online_data_migrations'] | bool"
|