Run online data migrations
We always run DB sync in deploy_tasks, ensuring that the database is up to date. We should follow up with online data migrations too. Doing this via docker_config has 2 purposes: * We can easily ensure this happens in a container with the right config files mounted. * We can even apply this via a minor update. This is important because we'll have to backport this all the way to Pike and apply it there using Pike containers, before upgrading to Queens containers. There's an additional issue to consider: In Puppet service variant we ran the online migrations for release X before upgrading to X+1, but the proposed Docker variant migrations for X run with upgrade to X. This means that when switching from non-containerized to containerized, we'll need to run migrations twice, to correctly switch between the aforementioned approaches. Change-Id: I2eb6c7c42d7e7aea4a78a892790e42bc5371f792 Closes-Bug: #1790474
This commit is contained in:
parent
514b0a9efb
commit
16405ff928
@ -120,7 +120,7 @@ Steps correlate to the following:
|
|||||||
a) step 4 baremetal
|
a) step 4 baremetal
|
||||||
b) step 4 containers
|
b) step 4 containers
|
||||||
c) Keystone containers post initialization (tenant,service,endpoint creation)
|
c) Keystone containers post initialization (tenant,service,endpoint creation)
|
||||||
5) Service activation (Pacemaker)
|
5) Service activation (Pacemaker), online data migration
|
||||||
a) step 5 baremetal
|
a) step 5 baremetal
|
||||||
b) step 5 containers
|
b) step 5 containers
|
||||||
|
|
||||||
|
@ -180,6 +180,26 @@ outputs:
|
|||||||
- ''
|
- ''
|
||||||
environment:
|
environment:
|
||||||
- KOLLA_CONFIG_STRATEGY=COPY_ALWAYS
|
- KOLLA_CONFIG_STRATEGY=COPY_ALWAYS
|
||||||
|
step_5:
|
||||||
|
cinder_api_online_migrations:
|
||||||
|
start_order: 2
|
||||||
|
image: *cinder_api_image
|
||||||
|
net: host
|
||||||
|
privileged: false
|
||||||
|
detach: false
|
||||||
|
user: root
|
||||||
|
volumes:
|
||||||
|
list_concat:
|
||||||
|
- {get_attr: [ContainersCommon, volumes]}
|
||||||
|
-
|
||||||
|
- /var/lib/config-data/cinder/etc/my.cnf.d/tripleo.cnf:/etc/my.cnf.d/tripleo.cnf:ro
|
||||||
|
- /var/lib/config-data/cinder/etc/cinder/:/etc/cinder/:ro
|
||||||
|
- /var/log/containers/cinder:/var/log/cinder
|
||||||
|
- /var/log/containers/httpd/cinder-api:/var/log/httpd
|
||||||
|
command:
|
||||||
|
- '/usr/bin/bootstrap_host_exec'
|
||||||
|
- 'cinder_api'
|
||||||
|
- "su cinder -s /bin/bash -c 'cinder-manage db online_data_migrations'"
|
||||||
cinder_api_cron:
|
cinder_api_cron:
|
||||||
image: *cinder_api_image
|
image: *cinder_api_image
|
||||||
net: host
|
net: host
|
||||||
@ -229,6 +249,11 @@ outputs:
|
|||||||
- when: step|int == 0
|
- when: step|int == 0
|
||||||
tags: common
|
tags: common
|
||||||
block:
|
block:
|
||||||
|
- name: get bootstrap nodeid
|
||||||
|
command: hiera -c /etc/puppet/hiera.yaml bootstrap_nodeid
|
||||||
|
register: bootstrap_node
|
||||||
|
- name: set is_bootstrap_node fact
|
||||||
|
set_fact: is_bootstrap_node={{bootstrap_node.stdout|lower == ansible_hostname|lower}}
|
||||||
- name: Check is cinder_api is deployed
|
- name: Check is cinder_api is deployed
|
||||||
command: systemctl is-enabled openstack-cinder-api
|
command: systemctl is-enabled openstack-cinder-api
|
||||||
ignore_errors: True
|
ignore_errors: True
|
||||||
@ -240,6 +265,18 @@ outputs:
|
|||||||
shell: systemctl is-active --quiet openstack-cinder-api
|
shell: systemctl is-active --quiet openstack-cinder-api
|
||||||
when: cinder_api_enabled|bool
|
when: cinder_api_enabled|bool
|
||||||
tags: validation
|
tags: validation
|
||||||
|
# NOTE: In puppet service variant, we ran release N online
|
||||||
|
# migrations before upgrade to release N+1. In docker
|
||||||
|
# service variant, we run release N online migrations
|
||||||
|
# after upgrade to release N. This means that during
|
||||||
|
# switch from non-containerized to containerized, we need
|
||||||
|
# to run both of these.
|
||||||
|
- name: Online data migration for Cinder before switching to containers
|
||||||
|
tags: pre-upgrade
|
||||||
|
when:
|
||||||
|
- is_bootstrap_node|bool
|
||||||
|
- cinder_api_enabled|bool
|
||||||
|
command: cinder-manage db online_data_migrations
|
||||||
- when: step|int == 2
|
- when: step|int == 2
|
||||||
block:
|
block:
|
||||||
- name: Stop and disable cinder_api service (pre-upgrade not under httpd)
|
- name: Stop and disable cinder_api service (pre-upgrade not under httpd)
|
||||||
|
@ -139,6 +139,22 @@ outputs:
|
|||||||
- /var/log/containers/httpd/ironic-api:/var/log/httpd
|
- /var/log/containers/httpd/ironic-api:/var/log/httpd
|
||||||
environment:
|
environment:
|
||||||
- KOLLA_CONFIG_STRATEGY=COPY_ALWAYS
|
- KOLLA_CONFIG_STRATEGY=COPY_ALWAYS
|
||||||
|
step_5:
|
||||||
|
ironic_online_migrations:
|
||||||
|
start_order: 2
|
||||||
|
image: *ironic_api_image
|
||||||
|
net: host
|
||||||
|
privileged: false
|
||||||
|
detach: false
|
||||||
|
user: root
|
||||||
|
volumes:
|
||||||
|
list_concat:
|
||||||
|
- {get_attr: [ContainersCommon, volumes]}
|
||||||
|
-
|
||||||
|
- /var/lib/config-data/ironic_api/etc/ironic:/etc/ironic:ro
|
||||||
|
- /var/log/containers/ironic:/var/log/ironic
|
||||||
|
- /var/log/containers/httpd/ironic-api:/var/log/httpd
|
||||||
|
command: "/usr/bin/bootstrap_host_exec ironic_api su ironic -s /bin/bash -c 'ironic-dbsync --config-file /etc/ironic/ironic.conf online_data_migrations'"
|
||||||
host_prep_tasks:
|
host_prep_tasks:
|
||||||
- name: create persistent logs directory
|
- name: create persistent logs directory
|
||||||
file:
|
file:
|
||||||
@ -158,6 +174,11 @@ outputs:
|
|||||||
- when: step|int == 0
|
- when: step|int == 0
|
||||||
tags: common
|
tags: common
|
||||||
block:
|
block:
|
||||||
|
- name: get bootstrap nodeid
|
||||||
|
command: hiera -c /etc/puppet/hiera.yaml bootstrap_nodeid
|
||||||
|
register: bootstrap_node
|
||||||
|
- name: set is_bootstrap_node fact
|
||||||
|
set_fact: is_bootstrap_node={{bootstrap_node.stdout|lower == ansible_hostname|lower}}
|
||||||
- name: Check if ironic_api is deployed
|
- name: Check if ironic_api is deployed
|
||||||
command: systemctl is-enabled --quiet openstack-ironic-api
|
command: systemctl is-enabled --quiet openstack-ironic-api
|
||||||
ignore_errors: True
|
ignore_errors: True
|
||||||
@ -192,6 +213,18 @@ outputs:
|
|||||||
when:
|
when:
|
||||||
- ironic_httpd_enabled|bool
|
- ironic_httpd_enabled|bool
|
||||||
- httpd_running|bool
|
- httpd_running|bool
|
||||||
|
# NOTE: In puppet service variant, we ran release N online
|
||||||
|
# migrations before upgrade to release N+1. In docker
|
||||||
|
# service variant, we run release N online migrations
|
||||||
|
# after upgrade to release N. This means that during
|
||||||
|
# switch from non-containerized to containerized, we need
|
||||||
|
# to run both of these.
|
||||||
|
- name: Online data migration for Ironic before switching to containers
|
||||||
|
tags: pre-upgrade
|
||||||
|
when:
|
||||||
|
- is_bootstrap_node|bool
|
||||||
|
- (ironic_httpd_enabled|bool and httpd_running|bool) or ironic_api_enabled|bool
|
||||||
|
command: ironic-dbsync --config-file /etc/ironic/ironic.conf online_data_migrations
|
||||||
- when: step|int == 2
|
- when: step|int == 2
|
||||||
block:
|
block:
|
||||||
- name: Stop and disable ironic_api service
|
- name: Stop and disable ironic_api service
|
||||||
|
@ -323,6 +323,14 @@ outputs:
|
|||||||
- ''
|
- ''
|
||||||
- - 'TRIPLEO_DEPLOY_IDENTIFIER='
|
- - 'TRIPLEO_DEPLOY_IDENTIFIER='
|
||||||
- {get_param: DeployIdentifier}
|
- {get_param: DeployIdentifier}
|
||||||
|
nova_online_migrations:
|
||||||
|
start_order: 2
|
||||||
|
image: *nova_api_image
|
||||||
|
net: host
|
||||||
|
detach: false
|
||||||
|
volumes: *nova_api_bootstrap_volumes
|
||||||
|
user: root
|
||||||
|
command: "/usr/bin/bootstrap_host_exec nova_api su nova -s /bin/bash -c '/usr/bin/nova-manage db online_data_migrations'"
|
||||||
metadata_settings:
|
metadata_settings:
|
||||||
get_attr: [NovaApiBase, role_data, metadata_settings]
|
get_attr: [NovaApiBase, role_data, metadata_settings]
|
||||||
host_prep_tasks: {get_attr: [NovaApiLogging, host_prep_tasks]}
|
host_prep_tasks: {get_attr: [NovaApiLogging, host_prep_tasks]}
|
||||||
@ -330,6 +338,11 @@ outputs:
|
|||||||
- when: step|int == 0
|
- when: step|int == 0
|
||||||
tags: common
|
tags: common
|
||||||
block:
|
block:
|
||||||
|
- name: get bootstrap nodeid
|
||||||
|
command: hiera -c /etc/puppet/hiera.yaml bootstrap_nodeid
|
||||||
|
register: bootstrap_node
|
||||||
|
- name: set is_bootstrap_node fact
|
||||||
|
set_fact: is_bootstrap_node={{bootstrap_node.stdout|lower == ansible_hostname|lower}}
|
||||||
- name: Check if nova_api is deployed
|
- name: Check if nova_api is deployed
|
||||||
command: systemctl is-enabled --quiet openstack-nova-api
|
command: systemctl is-enabled --quiet openstack-nova-api
|
||||||
ignore_errors: True
|
ignore_errors: True
|
||||||
@ -361,6 +374,18 @@ outputs:
|
|||||||
when:
|
when:
|
||||||
- nova_api_httpd_enabled|bool
|
- nova_api_httpd_enabled|bool
|
||||||
- httpd_running|bool
|
- httpd_running|bool
|
||||||
|
# NOTE: In puppet service variant, we ran release N online
|
||||||
|
# migrations before upgrade to release N+1. In docker
|
||||||
|
# service variant, we run release N online migrations
|
||||||
|
# after upgrade to release N. This means that during
|
||||||
|
# switch from non-containerized to containerized, we need
|
||||||
|
# to run both of these.
|
||||||
|
- name: Online data migration for Nova before switching to containers
|
||||||
|
tags: pre-upgrade
|
||||||
|
when:
|
||||||
|
- is_bootstrap_node|bool
|
||||||
|
- (nova_api_httpd_enabled|bool and httpd_running|bool) or nova_api_enabled|bool
|
||||||
|
command: nova-manage db online_data_migrations
|
||||||
- when: step|int == 2
|
- when: step|int == 2
|
||||||
block:
|
block:
|
||||||
- name: Stop and disable nova_api service
|
- name: Stop and disable nova_api service
|
||||||
|
Loading…
x
Reference in New Issue
Block a user