Skip to main content

Backup & Restore

Backing up and restoring a virtual cluster usually means to backup the namespace where vCluster is installed in. If you are using an external datastore like MySQL or Postgresql that is not running inside the same namespace as vCluster, you will need to create a separate backup for the datastore as well. Please refer to the appropriate docs for doing that.

Using velero

We recommend velero to backup virtual clusters, as it supports PV backup as well as single namespace backups. Other backup solutions should usually work as well.

Make sure your cluster supports volume snapshots to allow velero to backup persistent volumes and persistent volume claims that save the virtual cluster state. Alternatively, you can use velero's restic integration to backup the virtual cluster state.

Backing up a vCluster

Make sure to install the velero cli, velero server components and run the following command:

velero backup create <backup-name> --include-namespaces=my-vcluster-namespace

Verify backup was created successfully with:

velero backup describe <backup-name>

This should create a similar output to:

Name:         <backup-name>
Namespace: velero
Labels: velero.io/storage-location=default
Annotations: velero.io/source-cluster-k8s-gitversion=v1.24.0
velero.io/source-cluster-k8s-major-version=1
velero.io/source-cluster-k8s-minor-version=24

Phase: Completed

Errors: 0
Warnings: 0

Namespaces:
Included: test
Excluded: <none>

Resources:
Included: *
Excluded: <none>
Cluster-scoped: auto

...

Restoring a vCluster

After you have created a backup through either the velero cli or a schedule, you can restore a vCluster from the created backup via the velero cli:

velero restore create <restore-name> --from-backup <backup-name>

Verify the restore process via:

velero restore logs <restore-name>

This should recreate the vCluster workloads, configurations as well as vCluster state in the virtual cluster namespace.

Moving vClusters

Currently its quite difficult to move a vCluster from one namespace to another as there are objects that include a namespace reference such as the cluster role bindings or persistent volumes. velero supports namespace mapping that should work in most cases, but caution is still required as this might not work for every vCluster setup.

Using velero inside vCluster

To use velero for making backups you need to enable the hostpath-mapper component of vCluster. You can do this by adding this to your values.yaml file when creating or upgrading the vCluster

hostpathMapper:
enabled: true

This will start a the vCluster component for mapping the correct hostpaths as a Daemonset.

Once done you need to install velero cli as explained above and then connect to your vCluster, and install velero:

velero install --provider <provider> --bucket <bucket_name>  --secret-file <your_secret_file> --plugins velero/velero-plugin-for-<provider>:<semver> --use-restic

Make sure to fill up the appropriate fields like provider, bucket_name, secret-file etc. depending on your installation.

Once the installation is complete you can check the status of the velero resources:

$ kubectl get all -n velero
NAME READY STATUS RESTARTS AGE
pod/restic-5szkb 1/1 Running 0 118s
pod/velero-75c5479dfd-4x7sl 1/1 Running 0 118s

NAME DESIRED CURRENT READY UP-TO-DATE AVAILABLE NODE SELECTOR AGE
daemonset.apps/restic 1 1 1 1 1 <none> 118s

NAME READY UP-TO-DATE AVAILABLE AGE
deployment.apps/velero 1/1 1 1 119s

NAME DESIRED CURRENT READY AGE
replicaset.apps/velero-75c5479dfd 1 1 1 119s

Now you're ready to create a backup using restic:

velero backup create test1 --default-volumes-to-restic

Wait for the backup to complete and eventually you should see the following:

$ velero backup describe test1
Name: test1
Namespace: velero
Labels: velero.io/storage-location=default
Annotations: velero.io/source-cluster-k8s-gitversion=v1.25.0+k3s1
velero.io/source-cluster-k8s-major-version=1
velero.io/source-cluster-k8s-minor-version=25

Phase: Completed

Errors: 0
Warnings: 0

Namespaces:
Included: *
Excluded: <none>

Resources:
Included: *
Excluded: <none>
Cluster-scoped: auto

...