From 5f95cbded70f2ecfc0e7e4d8dd5ca84b8e2575df Mon Sep 17 00:00:00 2001 From: Sean McGinnis Date: Tue, 7 Feb 2017 20:20:25 -0600 Subject: [PATCH] Compact Mitaka database migrations This compacts all database migrations up to Mitaka into one initial schema to remove the need to apply every database change along the way. Change-Id: I7c9c8ec085131e569a1280bca8d0d75e0c62a8b8 --- cinder/db/migration.py | 2 +- .../versions/062_deleted_type_to_Integer.py | 30 -------------- .../versions/062_sqlite_upgrade.sql | 29 -------------- .../migrate_repo/versions/063_placeholder.py | 17 -------- .../064_add_restore_volume_id_to_backups.py | 26 ------------ .../065_add_replication_info_to_service.py | 30 -------------- ...add_allocated_id_column_to_reservations.py | 28 ------------- .../versions/067_readd_iscsi_targets_table.py | 40 ------------------- .../migrate_repo/versions/068_placeholder.py | 22 ---------- .../migrate_repo/versions/069_placeholder.py | 22 ---------- .../migrate_repo/versions/070_placeholder.py | 22 ---------- .../migrate_repo/versions/071_placeholder.py | 22 ---------- .../migrate_repo/versions/072_placeholder.py | 22 ---------- ...{061_cinder_init.py => 073_cinder_init.py} | 29 ++++---------- ...op_available_versions_and_iscsi_targets.py | 25 ------------ ...b-schema-from-mitaka-168ac06161e9ca0d.yaml | 5 +++ 16 files changed, 14 insertions(+), 357 deletions(-) delete mode 100644 cinder/db/sqlalchemy/migrate_repo/versions/062_deleted_type_to_Integer.py delete mode 100644 cinder/db/sqlalchemy/migrate_repo/versions/062_sqlite_upgrade.sql delete mode 100644 cinder/db/sqlalchemy/migrate_repo/versions/063_placeholder.py delete mode 100644 cinder/db/sqlalchemy/migrate_repo/versions/064_add_restore_volume_id_to_backups.py delete mode 100644 cinder/db/sqlalchemy/migrate_repo/versions/065_add_replication_info_to_service.py delete mode 100644 cinder/db/sqlalchemy/migrate_repo/versions/066_add_allocated_id_column_to_reservations.py delete mode 100644 cinder/db/sqlalchemy/migrate_repo/versions/067_readd_iscsi_targets_table.py delete mode 100644 cinder/db/sqlalchemy/migrate_repo/versions/068_placeholder.py delete mode 100644 cinder/db/sqlalchemy/migrate_repo/versions/069_placeholder.py delete mode 100644 cinder/db/sqlalchemy/migrate_repo/versions/070_placeholder.py delete mode 100644 cinder/db/sqlalchemy/migrate_repo/versions/071_placeholder.py delete mode 100644 cinder/db/sqlalchemy/migrate_repo/versions/072_placeholder.py rename cinder/db/sqlalchemy/migrate_repo/versions/{061_cinder_init.py => 073_cinder_init.py} (96%) delete mode 100644 cinder/db/sqlalchemy/migrate_repo/versions/073_drop_available_versions_and_iscsi_targets.py create mode 100644 releasenotes/notes/db-schema-from-mitaka-168ac06161e9ca0d.yaml diff --git a/cinder/db/migration.py b/cinder/db/migration.py index ba5bc3a76ec..c9f63d38454 100644 --- a/cinder/db/migration.py +++ b/cinder/db/migration.py @@ -28,7 +28,7 @@ from cinder import exception from cinder.i18n import _ -INIT_VERSION = 60 +INIT_VERSION = 72 _IMPL = None _LOCK = threading.Lock() diff --git a/cinder/db/sqlalchemy/migrate_repo/versions/062_deleted_type_to_Integer.py b/cinder/db/sqlalchemy/migrate_repo/versions/062_deleted_type_to_Integer.py deleted file mode 100644 index 415b076b2a4..00000000000 --- a/cinder/db/sqlalchemy/migrate_repo/versions/062_deleted_type_to_Integer.py +++ /dev/null @@ -1,30 +0,0 @@ -# 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. - -from sqlalchemy import Integer -from sqlalchemy import MetaData, Table - - -def upgrade(migrate_engine): - """Deleted col of volume_type_projects converted(tinyint->Int).""" - meta = MetaData() - meta.bind = migrate_engine - - volume_type_projects = Table('volume_type_projects', meta, autoload=True) - - if migrate_engine.name == 'postgresql': - # NOTE: PostgreSQL can't cast Boolean to int automatically - sql = 'ALTER TABLE volume_type_projects ALTER COLUMN deleted ' + \ - 'TYPE INTEGER USING deleted::integer' - migrate_engine.execute(sql) - else: - volume_type_projects.c.deleted.alter(Integer) diff --git a/cinder/db/sqlalchemy/migrate_repo/versions/062_sqlite_upgrade.sql b/cinder/db/sqlalchemy/migrate_repo/versions/062_sqlite_upgrade.sql deleted file mode 100644 index fe7cf988cea..00000000000 --- a/cinder/db/sqlalchemy/migrate_repo/versions/062_sqlite_upgrade.sql +++ /dev/null @@ -1,29 +0,0 @@ --- As sqlite does not support the DROP CHECK, we need to create --- the table, and move all the data to it. - -CREATE TABLE volume_type_projects_new ( - created_at DATETIME, - updated_at DATETIME, - deleted_at DATETIME, - deleted INTEGER, - id INTEGER NOT NULL, - volume_type_id VARCHAR(36), - project_id VARCHAR(255), - PRIMARY KEY (id), - FOREIGN KEY (volume_type_id) REFERENCES volume_types(id), - CONSTRAINT uniq_volume_type_projects0volume_type_id0project_id0deleted UNIQUE (volume_type_id, project_id, deleted) -); - -INSERT INTO volume_type_projects_new - SELECT created_at, - updated_at, - deleted_at, - deleted, - id, - volume_type_id, - project_id - FROM volume_type_projects; - -DROP TABLE volume_type_projects; - -ALTER TABLE volume_type_projects_new RENAME TO volume_type_projects; diff --git a/cinder/db/sqlalchemy/migrate_repo/versions/063_placeholder.py b/cinder/db/sqlalchemy/migrate_repo/versions/063_placeholder.py deleted file mode 100644 index b74fdeef0f2..00000000000 --- a/cinder/db/sqlalchemy/migrate_repo/versions/063_placeholder.py +++ /dev/null @@ -1,17 +0,0 @@ -# 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. - - -def upgrade(migrate_engine): - # This used to drop iscsi_targets, but since dropping it before L release - # stops using it breaks rolling upgrades we postpone the dropping until N. - pass diff --git a/cinder/db/sqlalchemy/migrate_repo/versions/064_add_restore_volume_id_to_backups.py b/cinder/db/sqlalchemy/migrate_repo/versions/064_add_restore_volume_id_to_backups.py deleted file mode 100644 index 8de90c6e2dc..00000000000 --- a/cinder/db/sqlalchemy/migrate_repo/versions/064_add_restore_volume_id_to_backups.py +++ /dev/null @@ -1,26 +0,0 @@ -# Copyright (c) 2015 Intel Corporation -# All Rights Reserved. -# -# 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. - -from sqlalchemy import Column, MetaData, String, Table - - -def upgrade(migrate_engine): - meta = MetaData() - meta.bind = migrate_engine - - backups = Table('backups', meta, autoload=True) - restore_volume_id = Column('restore_volume_id', String(length=36)) - - backups.create_column(restore_volume_id) diff --git a/cinder/db/sqlalchemy/migrate_repo/versions/065_add_replication_info_to_service.py b/cinder/db/sqlalchemy/migrate_repo/versions/065_add_replication_info_to_service.py deleted file mode 100644 index 3d8499a64d2..00000000000 --- a/cinder/db/sqlalchemy/migrate_repo/versions/065_add_replication_info_to_service.py +++ /dev/null @@ -1,30 +0,0 @@ -# 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. - -from sqlalchemy import Column -from sqlalchemy import Boolean, MetaData, String, Table - - -def upgrade(migrate_engine): - """Add replication info to services table.""" - meta = MetaData() - meta.bind = migrate_engine - - services = Table('services', meta, autoload=True) - replication_status = Column('replication_status', String(length=36), - default="not-capable") - active_backend_id = Column('active_backend_id', String(length=255)) - frozen = Column('frozen', Boolean, default=False) - - services.create_column(replication_status) - services.create_column(frozen) - services.create_column(active_backend_id) diff --git a/cinder/db/sqlalchemy/migrate_repo/versions/066_add_allocated_id_column_to_reservations.py b/cinder/db/sqlalchemy/migrate_repo/versions/066_add_allocated_id_column_to_reservations.py deleted file mode 100644 index 2ec286aede4..00000000000 --- a/cinder/db/sqlalchemy/migrate_repo/versions/066_add_allocated_id_column_to_reservations.py +++ /dev/null @@ -1,28 +0,0 @@ -# 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. - -from sqlalchemy import Column -from sqlalchemy import MetaData, Integer, Table, ForeignKey - - -def upgrade(migrate_engine): - """Add allocated_id to the reservations table.""" - meta = MetaData() - meta.bind = migrate_engine - - reservations = Table('reservations', meta, autoload=True) - Table('quotas', meta, autoload=True) - allocated_id = Column('allocated_id', Integer, ForeignKey('quotas.id'), - nullable=True) - reservations.create_column(allocated_id) - usage_id = reservations.c.usage_id - usage_id.alter(nullable=True) diff --git a/cinder/db/sqlalchemy/migrate_repo/versions/067_readd_iscsi_targets_table.py b/cinder/db/sqlalchemy/migrate_repo/versions/067_readd_iscsi_targets_table.py deleted file mode 100644 index c0ba4f3a3ea..00000000000 --- a/cinder/db/sqlalchemy/migrate_repo/versions/067_readd_iscsi_targets_table.py +++ /dev/null @@ -1,40 +0,0 @@ -# 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. - -from sqlalchemy import Boolean, Column, DateTime, ForeignKey -from sqlalchemy import Integer, MetaData, String, Table - - -def upgrade(migrate_engine): - meta = MetaData() - meta.bind = migrate_engine - Table('volumes', meta, autoload=True) - - table = Table( - 'iscsi_targets', meta, - Column('created_at', DateTime), - Column('updated_at', DateTime), - Column('deleted_at', DateTime), - Column('deleted', Boolean), - Column('id', Integer, primary_key=True, nullable=False), - Column('target_num', Integer), - Column('host', String(length=255)), - Column('volume_id', String(length=36), ForeignKey('volumes.id'), - nullable=True), - mysql_engine='InnoDB', - mysql_charset='utf8' - ) - - # We use checkfirst argument because this table may already exist if the - # migration is performed on a system that was on a migration earlier than - # 063 when performing the upgrade. - table.create(checkfirst=True) diff --git a/cinder/db/sqlalchemy/migrate_repo/versions/068_placeholder.py b/cinder/db/sqlalchemy/migrate_repo/versions/068_placeholder.py deleted file mode 100644 index 7f0c9af0d75..00000000000 --- a/cinder/db/sqlalchemy/migrate_repo/versions/068_placeholder.py +++ /dev/null @@ -1,22 +0,0 @@ -# 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. - -# This is a placeholder for Mitaka backports. -# Do not use this number for new Newton work. New work starts after -# all the placeholders. -# -# See this for more information: -# http://lists.openstack.org/pipermail/openstack-dev/2013-March/006827.html - - -def upgrade(migrate_engine): - pass diff --git a/cinder/db/sqlalchemy/migrate_repo/versions/069_placeholder.py b/cinder/db/sqlalchemy/migrate_repo/versions/069_placeholder.py deleted file mode 100644 index 7f0c9af0d75..00000000000 --- a/cinder/db/sqlalchemy/migrate_repo/versions/069_placeholder.py +++ /dev/null @@ -1,22 +0,0 @@ -# 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. - -# This is a placeholder for Mitaka backports. -# Do not use this number for new Newton work. New work starts after -# all the placeholders. -# -# See this for more information: -# http://lists.openstack.org/pipermail/openstack-dev/2013-March/006827.html - - -def upgrade(migrate_engine): - pass diff --git a/cinder/db/sqlalchemy/migrate_repo/versions/070_placeholder.py b/cinder/db/sqlalchemy/migrate_repo/versions/070_placeholder.py deleted file mode 100644 index 7f0c9af0d75..00000000000 --- a/cinder/db/sqlalchemy/migrate_repo/versions/070_placeholder.py +++ /dev/null @@ -1,22 +0,0 @@ -# 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. - -# This is a placeholder for Mitaka backports. -# Do not use this number for new Newton work. New work starts after -# all the placeholders. -# -# See this for more information: -# http://lists.openstack.org/pipermail/openstack-dev/2013-March/006827.html - - -def upgrade(migrate_engine): - pass diff --git a/cinder/db/sqlalchemy/migrate_repo/versions/071_placeholder.py b/cinder/db/sqlalchemy/migrate_repo/versions/071_placeholder.py deleted file mode 100644 index 7f0c9af0d75..00000000000 --- a/cinder/db/sqlalchemy/migrate_repo/versions/071_placeholder.py +++ /dev/null @@ -1,22 +0,0 @@ -# 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. - -# This is a placeholder for Mitaka backports. -# Do not use this number for new Newton work. New work starts after -# all the placeholders. -# -# See this for more information: -# http://lists.openstack.org/pipermail/openstack-dev/2013-March/006827.html - - -def upgrade(migrate_engine): - pass diff --git a/cinder/db/sqlalchemy/migrate_repo/versions/072_placeholder.py b/cinder/db/sqlalchemy/migrate_repo/versions/072_placeholder.py deleted file mode 100644 index 7f0c9af0d75..00000000000 --- a/cinder/db/sqlalchemy/migrate_repo/versions/072_placeholder.py +++ /dev/null @@ -1,22 +0,0 @@ -# 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. - -# This is a placeholder for Mitaka backports. -# Do not use this number for new Newton work. New work starts after -# all the placeholders. -# -# See this for more information: -# http://lists.openstack.org/pipermail/openstack-dev/2013-March/006827.html - - -def upgrade(migrate_engine): - pass diff --git a/cinder/db/sqlalchemy/migrate_repo/versions/061_cinder_init.py b/cinder/db/sqlalchemy/migrate_repo/versions/073_cinder_init.py similarity index 96% rename from cinder/db/sqlalchemy/migrate_repo/versions/061_cinder_init.py rename to cinder/db/sqlalchemy/migrate_repo/versions/073_cinder_init.py index e174d712e18..d5ca7918929 100644 --- a/cinder/db/sqlalchemy/migrate_repo/versions/061_cinder_init.py +++ b/cinder/db/sqlalchemy/migrate_repo/versions/073_cinder_init.py @@ -49,9 +49,10 @@ def define_tables(meta): Column('disabled_reason', String(255)), Column('modified_at', DateTime(timezone=False)), Column('rpc_current_version', String(36)), - Column('rpc_available_version', String(36)), Column('object_current_version', String(36)), - Column('object_available_version', String(36)), + Column('replication_status', String(36), default='not-capable'), + Column('frozen', Boolean, default=False), + Column('active_backend_id', String(255)), mysql_engine='InnoDB', mysql_charset='utf8' ) @@ -242,7 +243,7 @@ def define_tables(meta): Column('volume_type_id', String(36), ForeignKey('volume_types.id')), Column('project_id', String(255)), - Column('deleted', Boolean(create_constraint=True, name=None)), + Column('deleted', Integer), UniqueConstraint('volume_type_id', 'project_id', 'deleted'), mysql_engine='InnoDB', mysql_charset='utf8' @@ -295,21 +296,6 @@ def define_tables(meta): mysql_charset='utf8' ) - iscsi_targets = Table( - 'iscsi_targets', meta, - Column('created_at', DateTime), - Column('updated_at', DateTime), - Column('deleted_at', DateTime), - Column('deleted', Boolean), - Column('id', Integer, primary_key=True, nullable=False), - Column('target_num', Integer), - Column('host', String(255)), - Column('volume_id', String(36), ForeignKey('volumes.id'), - nullable=True), - mysql_engine='InnoDB', - mysql_charset='utf8' - ) - quota_classes = Table( 'quota_classes', meta, Column('created_at', DateTime(timezone=False)), @@ -354,11 +340,13 @@ def define_tables(meta): Column('usage_id', Integer(), ForeignKey('quota_usages.id'), - nullable=False), + nullable=True), Column('project_id', String(255), index=True), Column('resource', String(255)), Column('delta', Integer(), nullable=False), Column('expire', DateTime(timezone=False)), + Column('allocated_id', Integer, ForeignKey('quotas.id'), + nullable=True), Index('reservations_deleted_expire_idx', 'deleted', 'expire'), mysql_engine='InnoDB', @@ -409,6 +397,7 @@ def define_tables(meta): Column('num_dependent_backups', Integer, default=0), Column('snapshot_id', String(36)), Column('data_timestamp', DateTime), + Column('restore_volume_id', String(36)), mysql_engine='InnoDB', mysql_charset='utf8' ) @@ -510,7 +499,6 @@ def define_tables(meta): quality_of_service_specs, volume_types, volume_type_projects, - iscsi_targets, quotas, services, volume_metadata, @@ -548,7 +536,6 @@ def upgrade(migrate_engine): "volume_type_projects", "volumes", "volume_attachment", - "iscsi_targets", "migrate_version", "quotas", "services", diff --git a/cinder/db/sqlalchemy/migrate_repo/versions/073_drop_available_versions_and_iscsi_targets.py b/cinder/db/sqlalchemy/migrate_repo/versions/073_drop_available_versions_and_iscsi_targets.py deleted file mode 100644 index 72c24354350..00000000000 --- a/cinder/db/sqlalchemy/migrate_repo/versions/073_drop_available_versions_and_iscsi_targets.py +++ /dev/null @@ -1,25 +0,0 @@ -# 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. - -from sqlalchemy import MetaData, Table - - -def upgrade(migrate_engine): - meta = MetaData() - meta.bind = migrate_engine - - services = Table('services', meta, autoload=True) - services.c.rpc_available_version.drop() - services.c.object_available_version.drop() - - iscsi_targets = Table('iscsi_targets', meta, autoload=True) - iscsi_targets.drop() diff --git a/releasenotes/notes/db-schema-from-mitaka-168ac06161e9ca0d.yaml b/releasenotes/notes/db-schema-from-mitaka-168ac06161e9ca0d.yaml new file mode 100644 index 00000000000..0e2567f621a --- /dev/null +++ b/releasenotes/notes/db-schema-from-mitaka-168ac06161e9ca0d.yaml @@ -0,0 +1,5 @@ +--- +upgrade: + - The Cinder database can now only be upgraded from changes since the + Mitaka release. In order to upgrade from a version prior to that, + you must now upgrade to at least Mitaka first, then to Pike or later.