
This patch adds initial support for deploying multiple Nova cells. Splitting a nova-cell role out from the Nova role allows a more granular approach to deploying and configuring Nova services. A new enable_cells flag has been added that enables the support of multiple cells via the introduction of a super conductor in addition to cell-specific conductors. When this flag is not set (the default), nova is configured in the same manner as before - with a single conductor. The nova role now deploys the global services: * nova-api * nova-scheduler * nova-super-conductor (if enable_cells is true) The nova-cell role handles services specific to a cell: * nova-compute * nova-compute-ironic * nova-conductor * nova-libvirt * nova-novncproxy * nova-serialproxy * nova-spicehtml5proxy * nova-ssh This patch does not support using a single cell controller for managing more than one cell. Support for sharing a cell controller will be added in a future patch. This patch should be backwards compatible and is tested by existing CI jobs. A new CI job has been added that tests a multi-cell environment. ceph-mon has been removed from the play hosts list as it is not necessary - delegate_to does not require the host to be in the play. Documentation will be added in a separate patch. Partially Implements: blueprint support-nova-cells Co-Authored-By: Mark Goddard <mark@stackhpc.com> Change-Id: I810aad7d49db3f5a7fd9a2f0f746fd912fe03917
54 lines
2.1 KiB
YAML
54 lines
2.1 KiB
YAML
---
|
|
- import_tasks: get_cell_settings.yml
|
|
|
|
- name: Create cell
|
|
vars:
|
|
nova_conductor: "{{ nova_cell_services['nova-conductor'] }}"
|
|
become: true
|
|
kolla_docker:
|
|
action: "start_container"
|
|
command: bash -c 'sudo -E kolla_set_configs && nova-manage cell_v2 create_cell{% if nova_cell_name %} --name {{ nova_cell_name }}{% endif %}'
|
|
common_options: "{{ docker_common_options }}"
|
|
detach: False
|
|
image: "{{ nova_conductor.image }}"
|
|
labels:
|
|
BOOTSTRAP:
|
|
name: "create_cell_nova"
|
|
restart_policy: no
|
|
volumes: "{{ nova_cell_bootstrap_default_volumes + nova_cell_bootstrap_extra_volumes }}"
|
|
register: nova_cell_create
|
|
changed_when:
|
|
- nova_cell_create is success
|
|
failed_when:
|
|
- nova_cell_create.rc != 0
|
|
- '"already exists" not in nova_cell_create.stdout'
|
|
when:
|
|
- inventory_hostname == groups[nova_conductor.group][0] | default(None)
|
|
- nova_cell_settings | length == 0
|
|
|
|
- name: Update cell
|
|
vars:
|
|
nova_cell_database_url: "mysql+pymysql://{{ nova_cell_database_user }}:{{ nova_cell_database_password }}@{{ nova_cell_database_address | put_address_in_context('url') }}:{{ nova_cell_database_port }}/{{ nova_cell_database_name }}"
|
|
nova_conductor: "{{ nova_cell_services['nova-conductor'] }}"
|
|
become: true
|
|
kolla_docker:
|
|
action: "start_container"
|
|
command: "bash -c 'sudo -E kolla_set_configs && nova-manage cell_v2 update_cell --cell_uuid {{ nova_cell_settings.cell_uuid }}'"
|
|
common_options: "{{ docker_common_options }}"
|
|
detach: False
|
|
image: "{{ nova_conductor.image }}"
|
|
labels:
|
|
BOOTSTRAP:
|
|
name: "create_cell_nova"
|
|
restart_policy: no
|
|
volumes: "{{ nova_cell_bootstrap_default_volumes + nova_cell_bootstrap_extra_volumes }}"
|
|
register: nova_cell_updated
|
|
changed_when:
|
|
- nova_cell_updated is success
|
|
failed_when:
|
|
- nova_cell_updated.rc != 0
|
|
when:
|
|
- inventory_hostname == groups[nova_conductor.group][0] | default(None)
|
|
- nova_cell_settings | length > 0
|
|
- nova_cell_settings.cell_message_queue != nova_cell_notify_transport_url or nova_cell_settings.cell_database != nova_cell_database_url
|