You are looking at the documentation of a prior release. To read the documentation of the latest release, please
visit here.
VolumeSnapshot Using KubeStash
This guide will give you an overview of how VolumeSnapshot process works in KubeStash.
How Backup Process Works?
The following diagram shows how KubeStash creates VolumeSnapshot via Kubernetes native API. Open the image in a new tab to see the enlarged version.
The VolumeSnapshot process consists of the following steps:
- At first, a user creates a - Secretwith access credentials of the backend where the backed-up data will be stored.
- Then, she creates a - BackupStoragecustom resource that specifies the backend information, along with the- Secretcontaining the credentials needed to access the backend.
- KubeStash operator watches for - BackupStoragecustom resources. When it finds a- BackupStorageobject, it initializes the- BackupStorageby uploading the- metadata.yamlfile to the target storage.
- Then, she creates a - BackupConfigurationcustom resource that specifies the targeted workload/PVC, the Addon info with a specified task, etc. It also provides information about one or more repositories, each indicating a path and a- BackupStoragefor storing the metadata.
- KubeStash operator watches for - BackupConfigurationcustom resources.
- Once the KubeStash operator finds a - BackupConfigurationobject, it creates- Repositorywith the information specified in the BackupConfiguration.
- KubeStash operator watches for - Repositorycustom resources. When it finds the- Repositoryobject, it Initializes- Repositoryby uploading- repository.yamlfile to the- spec.sessions[*].repositories[*].directorypath specified in the- BackupConfiguration.
- Then, it creates a - CronJobwith the schedule specified in- BackupConfigurationto trigger backup periodically.
- On the next scheduled slot, the - CronJobtriggers a backup by creating a- BackupSessioncustom resource.
- KubeStash operator watches for - BackupSessioncustom resources.
- When it finds a - BackupSessionobject, it creates a- Snapshotcustom resource for each- Repositoryspecified in the respective session of the- BackupConfiguration.
- Then, it resolves the respective - Addonand- Functionand prepares a volume snapshotter- Jobdefinition.
- Then, It creates a volume snapshotter - Jobto capture snapshots of the targeted volumes.
- The volume snapshotter - Jobcreates a- VolumeSnapshotobject for each Persistent Volume Claim (PVC) associated the target and waits for the Container Storage Interface (CSI) driver to complete snapshotting. The VolumeSnapshot(s) are created with the following naming format:- <PVC name>-<BackupSession creation timestamp in Unix epoch seconds>
- Container Storage Interface (CSI) - external-snapshottercontroller watches for- VolumeSnapshotresources.
- When it finds a - VolumeSnapshotobject, it backups- VolumeSnapshotto the respective cloud storage.
- After the snapshotting process is completed, the volume snapshotter - Jobupdates the- status.components[*]field of the- Snapshotresources with- VolumeSnapshotinformation.
How Restore Process Works?
The following diagram shows how KubeStash restores PersistentVolumeClaims from snapshot using Kubernetes VolumeSnapshot API. Open the image in a new tab to see the enlarged version.
The restore process consists of the following steps:
- At first, a user creates a - RestoreSessioncustom resource that specifies the- volumeClaimTemplates, Addon info with a specified task, and a- DataSourcethat determines the- Snapshotfrom which the data will be restored.
- KubeStash operator watches for - RestoreSessioncustom resources.
- Once it finds a - RestoreSessionobject, it resolves the respective- Addonand- Functionand prepares a restore Job definition.
- Then, it creates a Restore - Jobto restore- PVCfrom the- volumeSnapshot.
- The restore job retrieves - VolumeSnapshotinformation from the Snapshot. Then it creates PVCs based on the- volumeClaimTemplateswith- spec.dataSourceReffield set to the respective- VolumeSnapshotname.
- Container Storage Interface (CSI) - external-snapshottercontroller watches for- PVCs.
- When it finds a new - PVCwith- spec.dataSourcefield set, it reads the information about the- VolumeSnapshot.
- The controller downloads the respective data from the cloud and populates the - PVC.
- Finally, when the restore process is completed, the restore - Jobupdates the- status.components[*]field of the- RestoreSessionwith restore information of the target application components.







