Run db sync manually by leader only

Without db_auto_create = False each barbican-worker attempts to run
alembic upgrades on the database whenever they start. This leads to
race conditions that can leave the sate of the database broken
(multiple alembic version that "overlap").

This change runs the barbican-manage db upgrade by the leader only
avoiding the race condition. charms.openstack also handles the
openstack upgrade process with a call to instance.db_sync.

Change-Id: I6b9498059c7057b73b1c3db0e355456c38b0510e
Closes-Bug: #1827690
This commit is contained in:
David Ames 2020-10-08 22:55:30 +00:00
parent 8c4c1a23d0
commit ca80b266ed
5 changed files with 24 additions and 4 deletions

View File

@ -1,4 +1,5 @@
includes: includes:
- layer:leadership
- layer:openstack-api - layer:openstack-api
- interface:mysql-shared - interface:mysql-shared
- interface:rabbitmq - interface:rabbitmq

View File

@ -145,6 +145,9 @@ class BarbicanCharm(charms_openstack.charm.HAOpenStackCharm):
group = "barbican" group = "barbican"
# This is the command to sync the database
sync_cmd = ['sudo', '-u', 'barbican', 'barbican-manage', 'db', 'upgrade']
def get_amqp_credentials(self): def get_amqp_credentials(self):
"""Provide the default amqp username and vhost as a tuple. """Provide the default amqp username and vhost as a tuple.

View File

@ -60,6 +60,20 @@ def render_stuff(*args):
'secrets.available')) 'secrets.available'))
barbican_charm.configure_ssl() barbican_charm.configure_ssl()
barbican_charm.assess_status() barbican_charm.assess_status()
reactive.set_flag('first-render')
@reactive.when('leadership.is_leader')
@reactive.when('charm.installed')
@reactive.when('shared-db.available')
@reactive.when('first-render')
@reactive.when_not('db.synced')
def run_db_migration():
with charm.provide_charm_instance() as barbican_charm:
barbican_charm.db_sync()
barbican_charm.restart_all()
reactive.set_state('db.synced')
barbican_charm.assess_status()
@reactive.when('secrets.new-plugin') @reactive.when('secrets.new-plugin')

View File

@ -3,10 +3,7 @@ debug = {{ options.debug }}
bind_host = {{ options.service_listen_info.barbican_worker.ip }} bind_host = {{ options.service_listen_info.barbican_worker.ip }}
bind_port = {{ options.service_listen_info.barbican_worker.port }} bind_port = {{ options.service_listen_info.barbican_worker.port }}
host_href = {{ options.external_endpoints.barbican_worker.url }} host_href = {{ options.external_endpoints.barbican_worker.url }}
db_auto_create = False
# Create the Barbican database on service startup. This is `true` by default
# up to Ussuri and `false` by default from Victoria on:
db_auto_create = true
{% include "parts/section-transport-url" %} {% include "parts/section-transport-url" %}

View File

@ -37,9 +37,14 @@ class TestRegisteredHooks(test_utils.TestRegisteredHooks):
'amqp.available',), 'amqp.available',),
'secrets_plugin_configure': ('secrets.new-plugin',), 'secrets_plugin_configure': ('secrets.new-plugin',),
'cluster_connected': ('ha.connected',), 'cluster_connected': ('ha.connected',),
'run_db_migration': ('leadership.is_leader',
'charm.installed',
'shared-db.available',
'first-render',),
}, },
'when_not': { 'when_not': {
'cluster_connected': ('ha.available',), 'cluster_connected': ('ha.available',),
'run_db_migration': ('db.synced',),
}, },
} }
# test that the hooks were registered via the # test that the hooks were registered via the