-- Licensed to the Apache Software Foundation (ASF) under one -- or more contributor license agreements. See the NOTICE file -- distributed with this work for additional information -- regarding copyright ownership. The ASF licenses this file -- to you 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. --step 1 -- drop all constraints for user_ip_address ALTER TABLE firewall_rules DROP foreign key fk_firewall_rules__ip_address ; ALTER TABLE remote_access_vpn DROP foreign key fk_remote_access_vpn__server_addr ; ALTER TABLE user_ip_address DROP primary key; --step 2A --schema+data changes ----------------------------------------user ip address table------------------------------------------------------------------------- ALTER TABLE `cloud`.`user_ip_address` ADD COLUMN `id` bigint unsigned NOT NULL auto_increment primary key; ALTER TABLE `cloud`.`user_ip_address` ADD COLUMN `source_network_id` bigint unsigned NOT NULL COMMENT 'network id ip belongs to'; ALTER TABLE `cloud`.`user_ip_address` ADD COLUMN `vm_id` bigint unsigned NOT NULL COMMENT 'foreign key to virtual machine id'; UPDATE user_ip_address SET source_network_id=(select network_id from vlan where vlan.id=user_ip_address.vlan_db_id); -------------------------------firewall_rules table ------------------------------------------------------------------------------------- ALTER TABLE `cloud`.`firewall_rules` ADD COLUMN `ip_address_id` bigint unsigned NOT NULL COMMENT 'foreign key to ip address table'; UPDATE firewall_rules set ip_address_id = (SELECT id from user_ip_address where public_ip_address = firewall_rules.ip_address); ALTER TABLE `cloud`.`firewall_rules` ADD COLUMN `is_static_nat` int(1) unsigned NOT NULL DEFAULT 0 COMMENT '1 if firewall rule is one to one nat rule'; UPDATE firewall_rules set protocol='tcp',is_static_nat=1 where protocol='NAT'; UPDATE firewall_rules set start_port = 1, end_port = 65535 where start_port = -1 AND end_port = -1; ALTER TABLE `cloud`.`firewall_rules` DROP COLUMN ip_address; -------------------------------port forwarding table --------------------------------------------------------------------------------------- UPDATE port_forwarding_rules set dest_port_start = 1, dest_port_end = 65535 where dest_port_start = -1 AND dest_port_end = -1; ----------------------------------remote_access_vpn table ---------------------------------------------------------------------------------- ALTER TABLE `cloud`.`remote_access_vpn` ADD COLUMN `vpn_server_addr_id` bigint unsigned NOT NULL COMMENT 'foreign key to ip address table'; UPDATE remote_access_vpn SET vpn_server_addr_id = (SELECT id from user_ip_address where public_ip_address = remote_access_vpn.vpn_server_addr); ALTER TABLE `cloud`.`remote_access_vpn` DROP COLUMN vpn_server_addr; --------------------------user_ip_address table re-visited------------------------------------------------------------------------------------ --step 2B --done in the java layer -- the updates the user ip address table with the vm id; using a 3 way join on firewall rules, user ip address, port forwarding tables -- to do this, run Db22beta4to22GAMigrationUtil.java --step 2C DROP VIEW if exists user_ip_address_view; ALTER TABLE `cloud`.`user_ip_address` ADD COLUMN `public_ip_address1` char(40) NOT NULL COMMENT 'the public ip address'; UPDATE user_ip_address SET public_ip_address1 = INET_NTOA(public_ip_address); ALTER TABLE `cloud`.`user_ip_address` DROP COLUMN public_ip_address; ALTER TABLE `cloud`.`user_ip_address` CHANGE public_ip_address1 public_ip_address char(40) NOT NULL COMMENT 'the public ip address'; DROP VIEW if exists port_forwarding_rules_view; ALTER TABLE `cloud`.`port_forwarding_rules` ADD COLUMN `dest_ip_address1` char(40) NOT NULL COMMENT 'the destination ip address'; UPDATE port_forwarding_rules SET dest_ip_address1 = INET_NTOA(dest_ip_address); ALTER TABLE `cloud`.`port_forwarding_rules` DROP COLUMN dest_ip_address; ALTER TABLE `cloud`.`port_forwarding_rules` CHANGE dest_ip_address1 dest_ip_address char(40) NOT NULL COMMENT 'the destination ip address'; --step3 (Run this ONLY after the java program is run: Db22beta4to22GAMigrationUtil.java) --------------------------------------------------------------------------------------------------------------------------------------------------- --recreate indices ALTER TABLE `cloud`.`firewall_rules` ADD CONSTRAINT `fk_firewall_rules__ip_address_id` FOREIGN KEY(`ip_address_id`) REFERENCES `user_ip_address`(`id`); ALTER TABLE `cloud`.`remote_access_vpn` ADD CONSTRAINT `fk_remote_access_vpn__server_addr` FOREIGN KEY `fk_remote_access_vpn__server_addr_id` (`vpn_server_addr_id`) REFERENCES `user_ip_address` (`id`); ALTER TABLE `cloud`.`op_it_work` ADD CONSTRAINT `fk_op_it_work__mgmt_server_id` FOREIGN KEY (`mgmt_server_id`) REFERENCES `mshost`(`msid`); ALTER TABLE `cloud`.`op_it_work` ADD CONSTRAINT `fk_op_it_work__instance_id` FOREIGN KEY (`instance_id`) REFERENCES `vm_instance`(`id`) ON DELETE CASCADE; ALTER TABLE `cloud`.`op_it_work` ADD INDEX `i_op_it_work__step`(`step`); ALTER TABLE `cloud`.`user_ip_address` ADD UNIQUE (source_network_id, public_ip_address); --step 4 (independent of above) ALTER TABLE `cloud`.`user_statistics` CHANGE `host_id` `device_id` bigint unsigned NOT NULL default 0; ALTER TABLE `cloud`.`user_statistics` ADD COLUMN `device_type` varchar(32) NOT NULL default 'DomainRouter'; UPDATE `cloud`.`user_statistics` us,`cloud`.`host` h SET us.device_type = h.type where us.device_id = h.id AND us.device_id > 0; ALTER TABLE `cloud`.`user_statistics` ADD UNIQUE (`account_id`, `data_center_id`, `public_ip_address`, `device_id`, `device_type`); ALTER TABLE `cloud`.`snapshots` modify `id` bigint unsigned UNIQUE NOT NULL AUTO_INCREMENT COMMENT 'Primary Key'; ----------------------usage changes (for cloud_usage database)-------------------------------------------------------------------------------------------------------------- ALTER TABLE `cloud_usage`.`user_statistics` ADD COLUMN `device_id` bigint unsigned NOT NULL default 0; ALTER TABLE `cloud_usage`.`user_statistics` ADD COLUMN `device_type` varchar(32) NOT NULL default 'DomainRouter'; ALTER TABLE `cloud_usage`.`user_statistics` ADD COLUMN `public_ip_address` varchar(15); UPDATE `cloud_usage`.`user_statistics` cus, `cloud`.`user_statistics` us SET cus.device_id=us.device_id, cus.device_type=us.device_type, cus.public_ip_address=us.public_ip_address WHERE cus.id = us.id; ALTER TABLE `cloud_usage`.`user_statistics` ADD UNIQUE (`account_id`, `data_center_id`, `public_ip_address`, `device_id`, `device_type`); INSERT INTO user_statistics ( account_id, data_center_id, device_id, device_type ) SELECT VM.account_id, VM.data_center_id, DR.id,'DomainRouter' FROM vm_instance VM, domain_router DR WHERE VM.id = DR.id; ALTER TABLE `cloud_usage`.`usage_network` ADD COLUMN `host_id` bigint unsigned NOT NULL default 0; ALTER TABLE `cloud_usage`.`usage_network` ADD COLUMN `host_type` varchar(32); ALTER TABLE `cloud_usage`.`usage_network` drop PRIMARY KEY; ALTER TABLE `cloud_usage`.`usage_network` add PRIMARY KEY (`account_id`, `zone_id`, `host_id`, `event_time_millis`); ALTER TABLE `cloud_usage`.`usage_ip_address` ADD COLUMN `id` bigint unsigned NOT NULL; ALTER TABLE `cloud_usage`.`usage_ip_address` ADD COLUMN `is_source_nat` smallint(1) NOT NULL default 0; update `cloud`.`usage_event` SET size = 0 where type = 'NET.IPASSIGN' and size is null; update `cloud_usage`.`usage_event` SET size = 0 where type = 'NET.IPASSIGN' and size is null; ----------------------volume units changed from MB to bytes. Update the same in existing usage_volume records and volume usage events which are not processed------------- update `cloud_usage`.`usage_volume` set size = (size * 1048576); update `cloud_usage`.`usage_event` set size = (size * 1048576) where type = 'VOLUME.CREATE' and processed = 0; ALTER TABLE `cloud_usage`.`cloud_usage` ADD COLUMN `type` varchar(32); CREATE TABLE `cloud_usage`.`usage_port_forwarding` ( `id` bigint unsigned NOT NULL, `zone_id` bigint unsigned NOT NULL, `account_id` bigint unsigned NOT NULL, `domain_id` bigint unsigned NOT NULL, `created` DATETIME NOT NULL, `deleted` DATETIME NULL ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `cloud_usage`.`usage_network_offering` ( `zone_id` bigint unsigned NOT NULL, `account_id` bigint unsigned NOT NULL, `domain_id` bigint unsigned NOT NULL, `vm_instance_id` bigint unsigned NOT NULL, `network_offering_id` bigint unsigned NOT NULL, `is_default` smallint(1) NOT NULL, `created` DATETIME NOT NULL, `deleted` DATETIME NULL ) ENGINE=InnoDB DEFAULT CHARSET=utf8;