Between Storage Arrays
User can migrate existing pre-provisioned volumes to another storage array by using the array migration feature.
NOTE: Currently only migration of standalone block volumes is supported.
Prerequisites
This feature needs to be planned in a controlled host environment.
If the user have native multipathing, the user has to run multipath list commands on all nodes to ensure that there are no faulty paths on the host. If any faulty paths exist, the user has to flush the paths, and have a clean setup before migration is triggered using the following command:
rescan-scsi-bus.sh --remove
On Storage Array
User has to configure physical SRDF connection between source array (where the volumes are currently provisioned) and target array (where the volumes should be migrated).
In Kubernetes
User need to ensure that migration group CRD is installed.
To install CRD, user can run the command as below:
kubectl create -f deploy/replicationcrds.all.yaml
Support Matrix
PowerMax | PowerStore | PowerScale | PowerFlex | Unity |
---|---|---|---|---|
Yes | No | No | No | No |
Installing Driver With sidecars
Dell-csi-migrator and dell-csi-node-rescanner sidecars are installed alongside with the driver, the user can enable it in the driver’s myvalues.yaml
file.
Sample:
# CSM module attributes
# Set this to true to enable migration
# Allowed values:
# "true" - migration is enabled
# "false" - migration is disabled
# Default value: "false"
migration:
enabled: true
# migrationPrefix: Determine if migration is enabled
# Default value: "migration.storage.dell.com"
# Examples: "migration.storage.dell.com"
migrationPrefix: "migration.storage.dell.com"
Target array configuration and endpoint needs to be updated in the driver’s myvalues.yaml file as shown below:
##########################
# PLATFORM ATTRIBUTES
##########################
# The CSI PowerMax ReverseProxy section to fill out the required configuration
defaultCredentialsSecret: powermax-creds
storageArrays:
- storageArrayId: "000000000000"
endpoint: https://00.000.000.00:0000
# backupEndpoint: https://backup-1.unisphe.re:8443
- storageArrayId: "000120001178"
endpoint: https://00.000.000.00:0000
# backupEndpoint: https://backup-2.unisphe.re:8443
After enabling the migration module the user can continue to install the CSI driver following usual installation procedure.
PowerMax Support
PowerMax supports the following migrations:
-
From a VMAX3 array to VMAX All Flash, or PowerMax array.
-
From a PowerMax array to another PowerMax array.
Basic Usage
To trigger array migration procedure, the user need to create the migration group for the required source and target array.
Creating the migration group will trigger reconcile action on the migrator sidecar that will call ArrayMigrate() on the CSI driver with actions migrate
or commit
. After the migrated state, the migration group will trigger reconcile on the node-rescanner sidecar.
Manual Migration Group Creation
User can find sample migration group manifest in the driver repository here. A sample is provided below, for convenience:
apiVersion: "replication.storage.dell.com/v1"
kind: DellCSIMigrationGroup
metadata:
# custom name of the migration group
# Default value: pmax-migration
name: pmax-migration
spec:
# driverName: exact name of CSI PowerMax driver
driverName: "csi-powermax.dellemc.com"
# sourceID: source ArrayID
sourceID: "000000001234"
# targetID: target ArrayID
targetID: "000000005678"
migrationGroupAttributes:
action: "migrate"
To create the migration group, use the below command:
kubectl -create -f <manifest.yaml>
After completion of migration, the migration group comes to deleting state after which the admin can manually delete the migration group with the below command:
kubectl -delete -f <manifest.yaml>
Post migration
The PV/PVCs will be mounted, up and running after migration and the pod can continue service as before.
LIMITATION: Any control operations like expansion, snapshot creation, replication workflows on migrated PV/PVCs will not be supported.