New to Stash? Please start here.
Snapshot is a representation of restic backup snapshot in a Kubernetes native way. With the help of Aggregated API Servers, Stash provides the users a way to
delete snapshots from restic repositories. Now, a user can view some crucial information of snapshots like
backed up path etc. In future, this will enable the users to recover a particular snapshot using stash.
Snapshot object’s structure created by backing up a
Deployment is shown below,
apiVersion: repositories.stash.appscode.com/v1alpha1 kind: Snapshot metadata: creationTimestamp: 2018-04-09T06:43:03Z labels: repository: deployment.stash-demo restic: stash-demo workload-kind: Deployment workload-name: stash-demo name: deployment.stash-demo-11156792 namespace: default selfLink: /apis/repositories.stash.appscode.com/v1alpha1/namespaces/default/snapshots/deployment.stash-demo-11156792 uid: 11156792ffe5a52ef076c4e7c74f79a4e6ad6f8d4d2a8a078cf9ee507a8f360c status: gid: 0 hostname: stash-demo paths: - /source/data tree: ab2311afd593e5ef6f95df652215c9d1102b1731b72e2784386350ae95f1a145 uid: 0 username: ""
Here, we are going to describe some important sections of
name filed in
metadata of a
Snapshot object represent its name. It follows this pattern,
<respective repository crd name>-<first 8 digits of snapshot id>
uid field in
Snapshot object represents complete restic snapshot id.
metadata field of a
Snapshot object represents the time when the snapshot was created.
Snapshot object maintains some important information using labels. These labels enable a user to filter
Snapshot according to
node-name etc. Details of these labels are given below.
|Name of the |
|Name of the |
Snapshot object has following status fields,
status.gidindicates the group identifier of the user who took this backup.
status.hostnameindicates the name of the host object whose data is backed up in this snapshot. For
ReplicationControllerit is workload name. For
DaemonSethostname is node name and for
StatefulSethostname is pod name.
status.pathindicates the path that is backed up in this snapshot.
treeof the restic snapshot. For more details see here.
status.uidindicates id of the user who took this backup. For
rootuser it is 0.
status.usernameindicates the name of the user.
status.tagsindicates tags of the snapshot.
# List Snapshots of all repositories in the current namespace $ kubectl get snapshot # List Snapshots of a particular repository $ kubectl get snapshot -l repository=deployment.stash-demo # List all Snapshots of a particular workload type $ kubectl get snapshot -l workload-kind=Deployment # List Snapshots of a particular workload $ kubectl get snapshot -l workload-name=stash-demo # List all Snapshots created by a particular restic $ kubectl get snapshot -l restic=stash-demo # List Snapshots of a particular pod(only for StatefulSet) $ kubectl get snapshot -l pod-name=stash-demo-0 # List Snapshots of a particular node(only for DaemonSet) kubectl get snapshot -l node-name=minikube # List Snapshot of specific repositories $ kubectl get snapshot -l 'repository in (deployment.stash-demo,statefulset.stash-demo-0)'
Viewing information of a particular Snapshot:
$ kubectl get snapshot <snapshot name> -o yaml # Example: $ kubectl get snapshot deployment.stash-demo-3d8cd994 -o yaml
apiVersion: repositories.stash.appscode.com/v1alpha1 kind: Snapshot metadata: creationTimestamp: 2018-04-09T10:06:04Z labels: repository: deployment.stash-demo restic: stash-demo workload-kind: Deployment workload-name: stash-demo name: deployment.stash-demo-3d8cd994 namespace: default selfLink: /apis/repositories.stash.appscode.com/v1alpha1/namespaces/default/snapshots/deployment.stash-demo-3d8cd994 uid: 3d8cd994a3bddcff1d16ac166601d93454d0eb31e2240801e7c1ec030e5af0bf status: gid: 0 hostname: stash-demo paths: - /source/data tree: ab2311afd593e5ef6f95df652215c9d1102b1731b72e2784386350ae95f1a145 uid: 0 username: ""
Deleting a particular Snapshot:
$ kubectl delete snapshot <snapshot name> # Example: $ kubectl delete snapshot statefulset.stash-demo-0-d690726d snapshot "statefulset.stash-demo-0-d690726d" deleted
Snapshotslisting facility with the help of aggregated api server. Stash start aggregated api server if any of the
MutatingWebhookis enabled. If both of the webhooks are disabled or if your cluster does not support aggregated api server or webhooks, you won’t able to list
Resticbackend, stash takes help of workload pod to provide snapshot list. In this case, workload pod must be running while listing
Resticbackend, you won’t able to list