Merge "db: Reorder initial migration"

This commit is contained in:
Zuul 2021-08-25 11:18:01 +00:00 committed by Gerrit Code Review
commit a2f0f57a06

View File

@ -907,6 +907,34 @@ def upgrade(migrate_engine):
migrate_engine.url.database)
migrate_engine.execute("ALTER TABLE %s Engine=InnoDB" % table)
workers = sa.Table('workers', meta, autoload=True)
# This is only necessary for mysql, and since the table is not in use this
# will only be a schema update.
if migrate_engine.name.startswith('mysql'):
try:
workers.c.updated_at.alter(mysql.DATETIME(fsp=6))
except Exception:
# MySQL v5.5 or earlier don't support sub-second resolution so we
# may have cleanup races in Active-Active configurations, that's
# why upgrading is recommended in that case.
# Code in Cinder is capable of working with 5.5, so for 5.5 there's
# no problem
pass
quota_usages = sa.Table('quota_usages', meta, autoload=True)
try:
quota_usages.c.resource.alter(type=sa.String(300))
except Exception:
# On MariaDB, max length varies depending on the version and the InnoDB
# page size [1], so it is possible to have error 1071 ('Specified key
# was too long; max key length is 767 bytes"). Since this migration is
# to resolve a corner case, deployments with those DB versions won't be
# covered.
# [1]: https://mariadb.com/kb/en/library/innodb-limitations/#page-sizes
if not migrate_engine.name.startswith('mysql'):
raise
# Set default quota class values
quota_classes = sa.Table('quota_classes', meta, autoload=True)
qci = quota_classes.insert()
@ -943,24 +971,10 @@ def upgrade(migrate_engine):
'hard_limit': CONF.quota_groups,
'deleted': False, })
workers = sa.Table('workers', meta, autoload=True)
# This is only necessary for mysql, and since the table is not in use this
# will only be a schema update.
if migrate_engine.name.startswith('mysql'):
try:
workers.c.updated_at.alter(mysql.DATETIME(fsp=6))
except Exception:
# MySQL v5.5 or earlier don't support sub-second resolution so we
# may have cleanup races in Active-Active configurations, that's
# why upgrading is recommended in that case.
# Code in Cinder is capable of working with 5.5, so for 5.5 there's
# no problem
pass
# TODO(geguileo): Once we remove support for MySQL 5.5 we have to create
# an upgrade migration to remove this row.
# Set workers table sub-second support sentinel
workers = sa.Table('workers', meta, autoload=True)
wi = workers.insert()
now = timeutils.utcnow().replace(microsecond=123)
wi.execute({'created_at': now,
@ -1006,19 +1020,6 @@ def upgrade(migrate_engine):
# prefix such as 'volumes_' or 'gigabytes_' to volume_type_name it
# will exceed the db length limit.
quota_usages = sa.Table('quota_usages', meta, autoload=True)
try:
quota_usages.c.resource.alter(type=sa.String(300))
except Exception:
# On MariaDB, max length varies depending on the version and the InnoDB
# page size [1], so it is possible to have error 1071 ('Specified key
# was too long; max key length is 767 bytes"). Since this migration is
# to resolve a corner case, deployments with those DB versions won't be
# covered.
# [1]: https://mariadb.com/kb/en/library/innodb-limitations/#page-sizes
if not migrate_engine.name.startswith('mysql'):
raise
# Create default volume type
vol_types = sa.Table("volume_types", meta, autoload=True)
volume_type_dict = {