Migration Cluster from vContainer to VKS
Last updated
Last updated
Tools used: Velero + vStorage (s3)
Process of migrating from vContainer to vKS (Customer + VNG Cloud)
Step 1: Evaluate the current version of the vContainer cluster and the corresponding vKS cluster to migrate. At this point, there will be 2 cases (step 2 and step 3)
Step 2: If the vContainer version is lower than the versions currently supported by vKS, then the Custom Resources (CRDs) need to be reviewed for compatibility with the new kubernetes versions.
If compatible with the new vKS version, continue with step 3.
If not compatible, need to manually update and reconfigure CRD as well as related Applications.
Step 3: If the vContainer version is supported by vKS (1.27, 1.28 and 1.29), then you need to check the resources on vContainer before backing up. You need to pay attention to the following types of resources:
PV/PVC: Velero does not support backup with hostPath type, only Local type is supported.
Ingress resources : Ingress resources managed by container-ingress-nginx-controller will not work after migration.
Label and Taint nodes : Velero does not re-attach Labels and Taints to nodes in the vKS
Step 4 : Backup resources on vContainer cluster
Step 5 : Restore resources on vKS cluster
Step 6 : Perform testing and adjustments
Check the existing StorageClasses on vContainer and create corresponding StorageClasses on vKS. Then perform 1:1 mapping of StorageClasses between vContainer and vKS cluster.
Example ConfigMap file in Step 3.
Velero does not support hostPath volume backup, only local.
For clusters using PV type hostPath, it is necessary to convert to local type as follows:
Note: Need to delete and redeploy the Application using PV type hostPath
Case 1: Type Local supports hostPath path
For example, PV hostPath is configured to mount at the /opt/data folder, convert to Local type and mount back to Pods, according to the following form:
Case 2: Type Local does not support the original hostPath path
When creating PV/PVC according to Case 1, Pod cannot mount PVC and an error appears
MountVolume.NewMounter initialization failed for volume "pvc" : path "/mnt/data" does not exist
Copy the data to a new folder (eg /var, /opt, /tmp, ...) and repeat Case 1, then mount the PVC into the Pod as usual:
Create a vStorage project, Container and corresponding S3 key to store backup data
On both clusters:
Create a credentials-velero file with the following content:
Install Velero CLI
Install Velero on 2 kubernetes clusters
Annotate the Persistent Volumes to be backed up
Annotate non-backup resources of kube-system
Annotate other resources (not marked in the velero_helper.sh file), such as CSI, LoadBalancer Controller, or other resources that you do not want to migrate (note that you need to label all resources of objects that do not need to be backed up).
For example, an application includes DaemonSet, Deployment, Pod, ... then it is necessary to mark labels for all those resources.
Perform check and attach Labels and Taints on vContainer nodes to vKS nodes before restore
Create 2 backups for Cluster resources and Namespace resources according to the syntax
View created backups and details of backed up resources (note the STATUS of the backup)
If in the vContainer cluster using CSI is cinder.csi.openstack.org , need to perform StorageClass mapping between 2 clusters vContainer and vKS
Mapping csi-sc-cinderplugin-nvme-5000 (vContainer) and vngcloud-nvme-5000-delete (vKS), similarly for other StorageClasses
In vKS, it is necessary to create corresponding StorageClasses.
Create sc-mapping.yaml file and apply on VKS cluster
Add permissions for Velero to restore data PersistentVolume
Create add-permission.yaml file and apply on VKS cluster
Perform restore in order
Note, for each restore, you need to check whether the restore process was successful or not before continuing to execute other commands.
In case of migrating to VKS and still using vcontainer-nginx-ingress-controller, it is necessary to change the Service type to LoadBalancer