Zone migration¶
Synopsis¶
display name: Zone migration
goal: hardware_maintenance
Zone migration using instance and volume migration
This is zone migration strategy to migrate many instances and volumes efficiently with minimum downtime for hardware maintenance.
Requirements¶
Metrics¶
None
Cluster data model¶
Default Watcher’s Compute cluster data model:
Nova cluster data model collector
The Nova cluster data model collector creates an in-memory representation of the resources exposed by the compute service.
Storage cluster data model is also required:
Cinder cluster data model collector
The Cinder cluster data model collector creates an in-memory representation of the resources exposed by the storage service.
Actions¶
Default Watcher’s actions:
action
description
migrate
Migrates a server to a destination nova-compute host
This action will allow you to migrate a server to another compute destination host. Migration type ‘live’ can only be used for migrating active VMs. Migration type ‘cold’ can be used for migrating non-active VMs as well active VMs, which will be shut down while migrating.
The action schema is:
schema = Schema({ 'resource_id': str, # should be a UUID 'migration_type': str, # choices -> "live", "cold" 'destination_node': str, 'source_node': str, })The resource_id is the UUID of the server to migrate. The source_node and destination_node parameters are respectively the source and the destination compute hostname (list of available compute hosts is returned by this command:
nova service-list --binary nova-compute
).Note
Nova API version must be 2.56 or above if destination_node parameter is given.
volume_migrate
Migrates a volume to destination node or type
By using this action, you will be able to migrate cinder volume. Migration type ‘swap’ can only be used for migrating attached volume. Migration type ‘migrate’ can be used for migrating detached volume to the pool of same volume type. Migration type ‘retype’ can be used for changing volume type of detached volume.
The action schema is:
schema = Schema({ 'resource_id': str, # should be a UUID 'migration_type': str, # choices -> "swap", "migrate","retype" 'destination_node': str, 'destination_type': str, })The resource_id is the UUID of cinder volume to migrate. The destination_node is the destination block storage pool name. (list of available pools are returned by this command:
cinder get-pools
) which is mandatory for migrating detached volume to the one with same volume type. The destination_type is the destination block storage type name. (list of available types are returned by this command:cinder type-list
) which is mandatory for migrating detached volume or swapping attached volume to the one with different volume type.
Planner¶
Default Watcher’s planner:
Weight planner implementation
This implementation builds actions with parents in accordance with weights. Set of actions having a higher weight will be scheduled before the other ones. There are two config options to configure: action_weights and parallelization.
Limitations
This planner requires to have action_weights and parallelization configs tuned well.
Configuration¶
Strategy parameters are:
parameter |
type |
default Value |
description |
---|---|---|---|
|
array |
None |
Compute nodes to migrate. |
|
array |
None |
Storage pools to migrate. |
|
integer |
6 |
The number of actions to be run in parallel in total. |
|
integer |
2 |
The number of actions to be run in parallel per compute node. |
|
integer |
2 |
The number of actions to be run in parallel per storage pool. |
|
object |
None |
List prioritizes instances and volumes. |
|
boolean |
False |
False: Instances will migrate after all volumes migrate. True: An instance will migrate after the attached volumes migrate. |
The elements of compute_nodes array are:
parameter |
type |
default Value |
description |
---|---|---|---|
|
string |
None |
Compute node from which instances migrate(mandatory). |
|
string |
None |
Compute node to which instances migrate. |
The elements of storage_pools array are:
parameter |
type |
default Value |
description |
---|---|---|---|
|
string |
None |
Storage pool from which volumes migrate(mandatory). |
|
string |
None |
Storage pool to which volumes migrate. |
|
string |
None |
Source volume type(mandatory). |
|
string |
None |
Destination volume type (mandatory). |
The elements of priority object are:
parameter |
type |
default Value |
description |
---|---|---|---|
|
array |
None |
Project names. |
|
array |
None |
Compute node names. |
|
array |
None |
Storage pool names. |
|
enum |
None |
Instance attributes. [“vcpu_num”, “mem_size”, “disk_size”, “created_at”] |
|
enum |
None |
Volume attributes. [“size”, “created_at”] |
Efficacy Indicator¶
[{'name': 'live_instance_migrate_ratio', 'description': 'Ratio of actual live migrated instances to planned live migrate instances.', 'unit': '%', 'value': 0}, {'name': 'cold_instance_migrate_ratio', 'description': 'Ratio of actual cold migrated instances to planned cold migrate instances.', 'unit': '%', 'value': 0}, {'name': 'volume_migrate_ratio', 'description': 'Ratio of actual detached volumes migrated to planned detached volumes migrate.', 'unit': '%', 'value': 0}, {'name': 'volume_update_ratio', 'description': 'Ratio of actual attached volumes migrated to planned attached volumes migrate.', 'unit': '%', 'value': 0}]
Algorithm¶
For more information on the zone migration strategy please refer to: http://specs.openstack.org/openstack/watcher-specs/specs/queens/implemented/zone-migration-strategy.html
How to use it ?¶
$ openstack optimize audittemplate create \
at1 hardware_maintenance --strategy zone_migration
$ openstack optimize audit create -a at1 \
-p compute_nodes='[{"src_node": "s01", "dst_node": "d01"}]'
External Links¶
None