From ccdb36717de18192bd89ca5d2b758b1c3f681ba2 Mon Sep 17 00:00:00 2001 From: Rudro-25 Date: Thu, 19 Sep 2024 19:56:21 +0600 Subject: [PATCH 1/2] Add zookeeper kubestash backup docs Signed-off-by: Rudro-25 --- docs/guides/zookeeper/backup/_index.md | 10 + .../zookeeper/backup/kubestash/_index.md | 10 + .../auto-backup/examples/backupstorage.yaml | 18 + .../examples/customize-backupblueprint.yaml | 37 + .../examples/default-backupblueprint.yaml | 37 + .../auto-backup/examples/retentionpolicy.yaml | 15 + .../examples/sample-zookeeper-2.yaml | 24 + .../examples/sample-zookeeper.yaml | 19 + .../backup/kubestash/auto-backup/index.md | 845 ++++++++++++++++++ .../backup/multiple-backends.yaml | 49 + .../customization/backup/resources-limit.yaml | 45 + .../customization/backup/specific-user.yaml | 41 + .../common/gcs-backupstorage.yaml | 17 + .../customization/common/retentionpolicy.yaml | 15 + .../common/s3-backupstorage.yaml | 18 + .../common/sample-zookeeper.yaml | 16 + .../backup/kubestash/customization/index.md | 252 ++++++ .../restore/resources-limit.yaml | 30 + .../customization/restore/specific-user.yaml | 26 + .../logical/examples/backupconfiguration.yaml | 36 + .../logical/examples/backupstorage.yaml | 18 + .../logical/examples/restored-zookeeper.yaml | 16 + .../logical/examples/restoresession.yaml | 21 + .../logical/examples/retentionpolicy.yaml | 15 + .../logical/examples/sample-zookeeper.yaml | 16 + .../backup/kubestash/logical/index.md | 690 ++++++++++++++ .../overview/images/backup_overview.svg | 1 + .../overview/images/kubedb_plus_kubestash.svg | 21 + .../overview/images/restore_overview.svg | 1 + .../backup/kubestash/overview/index.md | 98 ++ 30 files changed, 2457 insertions(+) create mode 100644 docs/guides/zookeeper/backup/_index.md create mode 100644 docs/guides/zookeeper/backup/kubestash/_index.md create mode 100644 docs/guides/zookeeper/backup/kubestash/auto-backup/examples/backupstorage.yaml create mode 100644 docs/guides/zookeeper/backup/kubestash/auto-backup/examples/customize-backupblueprint.yaml create mode 100644 docs/guides/zookeeper/backup/kubestash/auto-backup/examples/default-backupblueprint.yaml create mode 100644 docs/guides/zookeeper/backup/kubestash/auto-backup/examples/retentionpolicy.yaml create mode 100644 docs/guides/zookeeper/backup/kubestash/auto-backup/examples/sample-zookeeper-2.yaml create mode 100644 docs/guides/zookeeper/backup/kubestash/auto-backup/examples/sample-zookeeper.yaml create mode 100644 docs/guides/zookeeper/backup/kubestash/auto-backup/index.md create mode 100644 docs/guides/zookeeper/backup/kubestash/customization/backup/multiple-backends.yaml create mode 100644 docs/guides/zookeeper/backup/kubestash/customization/backup/resources-limit.yaml create mode 100644 docs/guides/zookeeper/backup/kubestash/customization/backup/specific-user.yaml create mode 100644 docs/guides/zookeeper/backup/kubestash/customization/common/gcs-backupstorage.yaml create mode 100644 docs/guides/zookeeper/backup/kubestash/customization/common/retentionpolicy.yaml create mode 100644 docs/guides/zookeeper/backup/kubestash/customization/common/s3-backupstorage.yaml create mode 100644 docs/guides/zookeeper/backup/kubestash/customization/common/sample-zookeeper.yaml create mode 100644 docs/guides/zookeeper/backup/kubestash/customization/index.md create mode 100644 docs/guides/zookeeper/backup/kubestash/customization/restore/resources-limit.yaml create mode 100644 docs/guides/zookeeper/backup/kubestash/customization/restore/specific-user.yaml create mode 100644 docs/guides/zookeeper/backup/kubestash/logical/examples/backupconfiguration.yaml create mode 100644 docs/guides/zookeeper/backup/kubestash/logical/examples/backupstorage.yaml create mode 100644 docs/guides/zookeeper/backup/kubestash/logical/examples/restored-zookeeper.yaml create mode 100644 docs/guides/zookeeper/backup/kubestash/logical/examples/restoresession.yaml create mode 100644 docs/guides/zookeeper/backup/kubestash/logical/examples/retentionpolicy.yaml create mode 100644 docs/guides/zookeeper/backup/kubestash/logical/examples/sample-zookeeper.yaml create mode 100644 docs/guides/zookeeper/backup/kubestash/logical/index.md create mode 100644 docs/guides/zookeeper/backup/kubestash/overview/images/backup_overview.svg create mode 100644 docs/guides/zookeeper/backup/kubestash/overview/images/kubedb_plus_kubestash.svg create mode 100644 docs/guides/zookeeper/backup/kubestash/overview/images/restore_overview.svg create mode 100644 docs/guides/zookeeper/backup/kubestash/overview/index.md diff --git a/docs/guides/zookeeper/backup/_index.md b/docs/guides/zookeeper/backup/_index.md new file mode 100644 index 0000000000..40f8d7586c --- /dev/null +++ b/docs/guides/zookeeper/backup/_index.md @@ -0,0 +1,10 @@ +--- +title: Backup & Restore ZooKeeper +menu: + docs_{{ .version }}: + identifier: guides-zk-backup + name: Backup & Restore + parent: zk-zookeeper-guides + weight: 40 +menu_name: docs_{{ .version }} +--- \ No newline at end of file diff --git a/docs/guides/zookeeper/backup/kubestash/_index.md b/docs/guides/zookeeper/backup/kubestash/_index.md new file mode 100644 index 0000000000..b1bd89d2e7 --- /dev/null +++ b/docs/guides/zookeeper/backup/kubestash/_index.md @@ -0,0 +1,10 @@ +--- +title: Backup & Restore PostgreSQL | KubeStash +menu: + docs_{{ .version }}: + identifier: guides-zk-backup-stashv2 + name: KubeStash (aka Stash 2.0) + parent: guides-zk-backup + weight: 50 +menu_name: docs_{{ .version }} +--- \ No newline at end of file diff --git a/docs/guides/zookeeper/backup/kubestash/auto-backup/examples/backupstorage.yaml b/docs/guides/zookeeper/backup/kubestash/auto-backup/examples/backupstorage.yaml new file mode 100644 index 0000000000..47934fdb25 --- /dev/null +++ b/docs/guides/zookeeper/backup/kubestash/auto-backup/examples/backupstorage.yaml @@ -0,0 +1,18 @@ +apiVersion: storage.kubestash.com/v1alpha1 +kind: BackupStorage +metadata: + name: s3-storage + namespace: demo +spec: + storage: + provider: s3 + s3: + endpoint: ap-south-1.linodeobjects.com + bucket: rudro + region: ap-south-1 + prefix: blueprint + secretName: s3-secret + usagePolicy: + allowedNamespaces: + from: All + deletionPolicy: WipeOut \ No newline at end of file diff --git a/docs/guides/zookeeper/backup/kubestash/auto-backup/examples/customize-backupblueprint.yaml b/docs/guides/zookeeper/backup/kubestash/auto-backup/examples/customize-backupblueprint.yaml new file mode 100644 index 0000000000..666595b149 --- /dev/null +++ b/docs/guides/zookeeper/backup/kubestash/auto-backup/examples/customize-backupblueprint.yaml @@ -0,0 +1,37 @@ +apiVersion: core.kubestash.com/v1alpha1 +kind: BackupBlueprint +metadata: + name: zookeeper-customize-backup-blueprint + namespace: demo +spec: + usagePolicy: + allowedNamespaces: + from: Same + backupConfigurationTemplate: + deletionPolicy: OnDelete + backends: + - name: s3-backend + storageRef: + namespace: demo + name: s3-storage + retentionPolicy: + name: demo-retention + namespace: demo + sessions: + - name: frequent-backup + sessionHistoryLimit: 3 + scheduler: + schedule: ${schedule} + jobTemplate: + backoffLimit: 1 + repositories: + - name: ${repoName} + backend: s3-backend + directory: ${namespace}/${targetName} + encryptionSecret: + name: encrypt-secret + namespace: demo + addon: + name: zookeeper-addon + tasks: + - name: logical-backup \ No newline at end of file diff --git a/docs/guides/zookeeper/backup/kubestash/auto-backup/examples/default-backupblueprint.yaml b/docs/guides/zookeeper/backup/kubestash/auto-backup/examples/default-backupblueprint.yaml new file mode 100644 index 0000000000..e0e0295f7a --- /dev/null +++ b/docs/guides/zookeeper/backup/kubestash/auto-backup/examples/default-backupblueprint.yaml @@ -0,0 +1,37 @@ +apiVersion: core.kubestash.com/v1alpha1 +kind: BackupBlueprint +metadata: + name: zookeeper-default-backup-blueprint + namespace: demo +spec: + usagePolicy: + allowedNamespaces: + from: Same + backupConfigurationTemplate: + deletionPolicy: OnDelete + backends: + - name: s3-backend + storageRef: + namespace: demo + name: s3-storage + retentionPolicy: + name: demo-retention + namespace: demo + sessions: + - name: frequent-backup + sessionHistoryLimit: 3 + scheduler: + schedule: "*/5 * * * *" + jobTemplate: + backoffLimit: 1 + repositories: + - name: default-blueprint + backend: s3-backend + directory: /default-blueprint + encryptionSecret: + name: encrypt-secret + namespace: demo + addon: + name: zookeeper-addon + tasks: + - name: logical-backup \ No newline at end of file diff --git a/docs/guides/zookeeper/backup/kubestash/auto-backup/examples/retentionpolicy.yaml b/docs/guides/zookeeper/backup/kubestash/auto-backup/examples/retentionpolicy.yaml new file mode 100644 index 0000000000..3af90371d1 --- /dev/null +++ b/docs/guides/zookeeper/backup/kubestash/auto-backup/examples/retentionpolicy.yaml @@ -0,0 +1,15 @@ +apiVersion: storage.kubestash.com/v1alpha1 +kind: RetentionPolicy +metadata: + name: demo-retention + namespace: demo +spec: + default: true + failedSnapshots: + last: 2 + maxRetentionPeriod: 2mo + successfulSnapshots: + last: 5 + usagePolicy: + allowedNamespaces: + from: Same \ No newline at end of file diff --git a/docs/guides/zookeeper/backup/kubestash/auto-backup/examples/sample-zookeeper-2.yaml b/docs/guides/zookeeper/backup/kubestash/auto-backup/examples/sample-zookeeper-2.yaml new file mode 100644 index 0000000000..884ccec449 --- /dev/null +++ b/docs/guides/zookeeper/backup/kubestash/auto-backup/examples/sample-zookeeper-2.yaml @@ -0,0 +1,24 @@ +apiVersion: kubedb.com/v1alpha2 +kind: ZooKeeper +metadata: + name: sample-zookeeper-2 + namespace: demo + annotations: + blueprint.kubestash.com/name: zookeeper-customize-backup-blueprint + blueprint.kubestash.com/namespace: demo + variables.kubestash.com/schedule: "*/10 * * * *" + variables.kubestash.com/repoName: customize-blueprint + variables.kubestash.com/namespace: demo + variables.kubestash.com/targetName: sample-zookeeper-2 + variables.kubestash.com/targetedDatabase: zookeeper +spec: + version: "3.8.3" + adminServerPort: 8080 + replicas: 3 + storage: + resources: + requests: + storage: "1Gi" + accessModes: + - ReadWriteOnce + deletionPolicy: "WipeOut" \ No newline at end of file diff --git a/docs/guides/zookeeper/backup/kubestash/auto-backup/examples/sample-zookeeper.yaml b/docs/guides/zookeeper/backup/kubestash/auto-backup/examples/sample-zookeeper.yaml new file mode 100644 index 0000000000..208546353d --- /dev/null +++ b/docs/guides/zookeeper/backup/kubestash/auto-backup/examples/sample-zookeeper.yaml @@ -0,0 +1,19 @@ +apiVersion: kubedb.com/v1alpha2 +kind: ZooKeeper +metadata: + name: sample-zookeeper + namespace: demo + annotations: + blueprint.kubestash.com/name: zookeeper-default-backup-blueprint + blueprint.kubestash.com/namespace: demo +spec: + version: "3.8.3" + adminServerPort: 8080 + replicas: 3 + storage: + resources: + requests: + storage: "1Gi" + accessModes: + - ReadWriteOnce + deletionPolicy: "WipeOut" \ No newline at end of file diff --git a/docs/guides/zookeeper/backup/kubestash/auto-backup/index.md b/docs/guides/zookeeper/backup/kubestash/auto-backup/index.md new file mode 100644 index 0000000000..f2afb847bd --- /dev/null +++ b/docs/guides/zookeeper/backup/kubestash/auto-backup/index.md @@ -0,0 +1,845 @@ +--- +title: ZooKeeper Auto-Backup | KubeStash +description: Backup ZooKeeper using KubeStash Auto-Backup +menu: + docs_{{ .version }}: + identifier: guides-zk-auto-backup-stashv2 + name: Auto-Backup + parent: guides-zk-backup-stashv2 + weight: 30 +menu_name: docs_{{ .version }} +section_menu_id: guides +--- + +# Backup ZooKeeper using KubeStash Auto-Backup + +KubeStash can automatically be configured to backup any `ZooKeeper` in your cluster. KubeStash enables cluster administrators to deploy backup `blueprints` ahead of time so database owners can easily backup any `ZooKeeper` database with a few annotations. + +In this tutorial, we are going to show how you can configure a backup blueprint for `ZooKeeper` in your cluster and backup them with a few annotations. + +## Before You Begin + +- At first, you need to have a Kubernetes cluster, and the `kubectl` command-line tool must be configured to communicate with your cluster. If you do not already have a cluster, you can create one by using `Minikube` or `Kind`. +- Install `KubeDB` in your cluster following the steps [here](/docs/setup/README.md). +- Install `KubeStash` in your cluster following the steps [here](https://kubestash.com/docs/latest/setup/install/kubestash). +- Install KubeStash `kubectl` plugin following the steps [here](https://kubestash.com/docs/latest/setup/install/kubectl-plugin/). +- If you are not familiar with how KubeStash backup and restore `ZooKeeper`, please check the following guide [here](/docs/guides/zookeeper/backup/kubestash/overview/index.md). + +You should be familiar with the following `KubeStash` concepts: + +- [BackupStorage](https://kubestash.com/docs/latest/concepts/crds/backupstorage/) +- [BackupConfiguration](https://kubestash.com/docs/latest/concepts/crds/backupconfiguration/) +- [BackupSession](https://kubestash.com/docs/latest/concepts/crds/backupsession/) +- [RestoreSession](https://kubestash.com/docs/latest/concepts/crds/restoresession/) +- [Addon](https://kubestash.com/docs/latest/concepts/crds/addon/) +- [Function](https://kubestash.com/docs/latest/concepts/crds/function/) +- [Task](https://kubestash.com/docs/latest/concepts/crds/addon/#task-specification) + +To keep everything isolated, we are going to use a separate namespace called `demo` throughout this tutorial. + +```bash +$ kubectl create ns demo +namespace/demo created +``` + +> **Note:** YAML files used in this tutorial are stored in [docs/guides/zookeeper/backup/kubestash/auto-backup/examples](https://github.com/kubedb/docs/raw/{{< param "info.version" >}}/docs/guides/zookeeper/backup/kubestash/auto-backup/examples) directory of [kubedb/docs](https://github.com/kubedb/docs) repository. + +### Prepare Backend + +We are going to store our backed up data into a `s3` bucket. We have to create a `Secret` with necessary credentials and a `BackupStorage` CR to use this backend. If you want to use a different backend, please read the respective backend configuration doc from [here](https://kubestash.com/docs/latest/guides/backends/overview/). + +**Create Secret:** + +Let's create a secret called `s3-secret` with access credentials to our desired GCS bucket, + +```bash +$ echo -n '' > AWS_ACCESS_KEY_ID +$ echo -n '' > AWS_SECRET_ACCESS_KEY +$ kubectl create secret generic -n demo s3-secret \ + --from-file=./AWS_ACCESS_KEY_ID \ + --from-file=./AWS_SECRET_ACCESS_KEY +secret/s3-secret created +``` + +**Create BackupStorage:** + +Now, create a `BackupStorage` using this secret. Below is the YAML of `BackupStorage` CR we are going to create, + +```yaml +apiVersion: storage.kubestash.com/v1alpha1 +kind: BackupStorage +metadata: + name: s3-storage + namespace: demo +spec: + storage: + provider: s3 + s3: + endpoint: ap-south-1.linodeobjects.com + bucket: rudro + region: ap-south-1 + prefix: blueprint + secretName: s3-secret + usagePolicy: + allowedNamespaces: + from: All + deletionPolicy: WipeOut +``` + +Let's create the BackupStorage we have shown above, + +```bash +$ kubectl apply -f https://github.com/kubedb/docs/raw/{{< param "info.version" >}}/docs/guides/zookeeper/backup/kubestash/auto-backup/examples/backupstorage.yaml +backupstorage.storage.kubestash.com/s3-storage created +``` + +Now, we are ready to backup our database to our desired backend. + +**Create RetentionPolicy:** + +Now, let's create a `RetentionPolicy` to specify how the old Snapshots should be cleaned up. + +Below is the YAML of the `RetentionPolicy` object that we are going to create, + +```yaml +apiVersion: storage.kubestash.com/v1alpha1 +kind: RetentionPolicy +metadata: + name: demo-retention + namespace: demo +spec: + default: true + failedSnapshots: + last: 2 + maxRetentionPeriod: 2mo + successfulSnapshots: + last: 5 + usagePolicy: + allowedNamespaces: + from: All +``` + +Let’s create the above `RetentionPolicy`, + +```bash +$ kubectl apply -f https://github.com/kubedb/docs/raw/{{< param "info.version" >}}/docs/guides/zookeeper/backup/kubestash/auto-backup/examples/retentionpolicy.yaml +retentionpolicy.storage.kubestash.com/demo-retention created +``` + +**Create Secret:** + +We also need to create a secret with a `Restic` password for backup data encryption. + +Let's create a secret called `encrypt-secret` with the Restic password, + +```bash +$ echo -n 'changeit' > RESTIC_PASSWORD +$ kubectl create secret generic -n demo encrypt-secret \ + --from-file=./RESTIC_PASSWORD \ +secret "encrypt-secret" created +``` + +## Auto-backup with default configurations + +In this section, we are going to backup a `ZooKeeper` of `demo` namespace. We are going to use the default configurations which will be specified in the `BackupBlueprint` CR. + +**Prepare Backup Blueprint** + +A `BackupBlueprint` allows you to specify a template for the `Repository`,`Session` or `Variables` of `BackupConfiguration` in a Kubernetes native way. + +Now, we have to create a `BackupBlueprint` CR with a blueprint for `BackupConfiguration` object. + +```yaml +apiVersion: core.kubestash.com/v1alpha1 +kind: BackupBlueprint +metadata: + name: zookeeper-default-backup-blueprint + namespace: demo +spec: + usagePolicy: + allowedNamespaces: + from: All + backupConfigurationTemplate: + deletionPolicy: OnDelete + backends: + - name: s3-backend + storageRef: + namespace: demo + name: s3-storage + retentionPolicy: + name: demo-retention + namespace: demo + sessions: + - name: frequent-backup + sessionHistoryLimit: 3 + scheduler: + schedule: "*/5 * * * *" + jobTemplate: + backoffLimit: 1 + repositories: + - name: default-blueprint + backend: s3-backend + directory: /default-blueprint + encryptionSecret: + name: encrypt-secret + namespace: demo + addon: + name: zookeeper-addon + tasks: + - name: logical-backup +``` + +Here, + +- `.spec.backupConfigurationTemplate.backends[*].storageRef` refers our earlier created `s3-storage` backupStorage. +- `.spec.backupConfigurationTemplate.sessions[*].schedule` specifies that we want to backup the database at `5 minutes` interval. + +Let's create the `BackupBlueprint` we have shown above, + +```bash +$ kubectl apply -f https://github.com/kubedb/docs/raw/{{< param "info.version" >}}/docs/guides/zookeeper/backup/kubestash/auto-backup/examples/default-backupblueprint.yaml +backupblueprint.core.kubestash.com/zookeeper-default-backup-blueprint created +``` + +Now, we are ready to backup our `ZooKeeper` using few annotations. + +**Create Database** + +Now, we are going to create an `ZooKeeper` CR in demo namespace. + +Below is the YAML of the `ZooKeeper` object that we are going to create, + +```yaml +apiVersion: kubedb.com/v1alpha2 +kind: ZooKeeper +metadata: + name: sample-zookeeper + namespace: demo + annotations: + blueprint.kubestash.com/name: zookeeper-default-backup-blueprint + blueprint.kubestash.com/namespace: demo +spec: + version: "3.8.3" + adminServerPort: 8080 + replicas: 3 + storage: + resources: + requests: + storage: "1Gi" + accessModes: + - ReadWriteOnce + deletionPolicy: "WipeOut" +``` + +Here, + +- `.spec.annotations.blueprint.kubestash.com/name: zookeeper-default-backup-blueprint` specifies the name of the `BackupBlueprint` that will use in backup. +- `.spec.annotations.blueprint.kubestash.com/namespace: demo` specifies the name of the `namespace` where the `BackupBlueprint` resides. + +Let's create the `ZooKeeper` we have shown above, + +```bash +$ kubectl apply -f https://github.com/kubedb/docs/raw/{{< param "info.version" >}}/docs/guides/zookeeper/backup/kubestash/auto-backup/examples/sample-zookeeper.yaml +zookeeper.kubedb.com/sample-zookeeper created +``` + +**Verify BackupConfiguration** + +If everything goes well, KubeStash should create a `BackupConfiguration` for our ZooKeeper in demo namespace and the phase of that `BackupConfiguration` should be `Ready`. Verify the `BackupConfiguration` object by the following command, + +```bash +$ kubectl get backupconfiguration -n demo +NAME PHASE PAUSED AGE +appbinding-sample-zookeeper Ready 2m50m +``` + +Now, let’s check the YAML of the `BackupConfiguration`. + +```bash +$ kubectl get backupconfiguration -n demo appbinding-sample-zookeeper -o yaml +``` + +```yaml +apiVersion: core.kubestash.com/v1alpha1 +kind: BackupConfiguration +metadata: + creationTimestamp: "2024-09-19T08:50:44Z" + finalizers: + - kubestash.com/cleanup + generation: 1 + labels: + app.kubernetes.io/managed-by: kubestash.com + kubestash.com/invoker-name: zookeeper-default-backup-blueprint + kubestash.com/invoker-namespace: demo + name: appbinding-sample-zookeeper + namespace: demo + resourceVersion: "1509329" + uid: 1e99efc6-7ede-4c32-9dd0-da9dec0eb28c +spec: + backends: + - name: s3-backend + retentionPolicy: + name: demo-retention + namespace: demo + storageRef: + name: s3-storage + namespace: demo + sessions: + - addon: + name: zookeeper-addon + tasks: + - name: logical-backup + name: frequent-backup + repositories: + - backend: s3-backend + directory: /default-blueprint + encryptionSecret: + name: encrypt-secret + namespace: demo + name: default-blueprint + scheduler: + jobTemplate: + backoffLimit: 1 + template: + controller: {} + metadata: {} + spec: + resources: {} + schedule: '*/5 * * * *' + sessionHistoryLimit: 3 + target: + apiGroup: kubedb.com + kind: ZooKeeper + name: sample-zookeeper + namespace: demo +status: + backends: + - name: s3-backend + ready: true + retentionPolicy: + found: true + ref: + name: demo-retention + namespace: demo + storage: + phase: Ready + ref: + name: s3-storage + namespace: demo + conditions: + - lastTransitionTime: "2024-09-19T08:50:44Z" + message: Validation has been passed successfully. + reason: ResourceValidationPassed + status: "True" + type: ValidationPassed + dependencies: + - found: true + kind: Addon + name: zookeeper-addon + phase: Ready + repositories: + - name: default-blueprint + phase: Ready + sessions: + - conditions: + - lastTransitionTime: "2024-09-19T08:50:54Z" + message: Scheduler has been ensured successfully. + reason: SchedulerEnsured + status: "True" + type: SchedulerEnsured + - lastTransitionTime: "2024-09-19T08:50:54Z" + message: Initial backup has been triggered successfully. + reason: SuccessfullyTriggeredInitialBackup + status: "True" + type: InitialBackupTriggered + name: frequent-backup + targetFound: true + +``` + +Notice the `spec.backends`, `spec.sessions` and `spec.target` sections, KubeStash automatically resolved those info from the `BackupBluePrint` and created above `BackupConfiguration`. + +**Verify BackupSession:** + +KubeStash triggers an instant backup as soon as the `BackupConfiguration` is ready. After that, backups are scheduled according to the specified schedule. + +```bash +$ kubectl get backupsession -n demo -w +NAME INVOKER-TYPE INVOKER-NAME PHASE DURATION AGE +appbinding-sample-zookeeper-frequent-backup-1726735844 BackupConfiguration appbinding-sample-zookeeper Succeeded 23s 6m40s +``` + +We can see from the above output that the backup session has succeeded. Now, we are going to verify whether the backed up data has been stored in the backend. + +**Verify Backup:** + +Once a backup is complete, KubeStash will update the respective `Repository` CR to reflect the backup. Check that the repository `sample-zookeeper-backup` has been updated by the following command, + +```bash +$ kubectl get repository -n demo default-blueprint +NAME INTEGRITY SNAPSHOT-COUNT SIZE PHASE LAST-SUCCESSFUL-BACKUP AGE +default-blueprint true 3 1.559 KiB Ready 80s 7m32s +``` + +At this moment we have one `Snapshot`. Run the following command to check the respective `Snapshot` which represents the state of a backup run for an application. + +```bash +$ kubectl get snapshots -n demo -l=kubestash.com/repo-name=default-blueprint +NAME REPOSITORY SESSION SNAPSHOT-TIME DELETION-POLICY PHASE AGE +default-blueprint-appbinding-samgres-frequent-backup-1726736101 default-blueprint frequent-backup 2024-09-19T08:55:01Z Delete Succeeded 7m48s +``` + +> Note: KubeStash creates a `Snapshot` with the following labels: +> - `kubestash.com/app-ref-kind: ` +> - `kubestash.com/app-ref-name: ` +> - `kubestash.com/app-ref-namespace: ` +> - `kubestash.com/repo-name: ` +> +> These labels can be used to watch only the `Snapshot`s related to our target Database or `Repository`. + +If we check the YAML of the `Snapshot`, we can find the information about the backed up components of the Database. + +```bash +$ kubectl get snapshots -n demo default-blueprint-appbinding-sameper-frequent-backup-1726736101 -oyaml +``` + +```yaml +apiVersion: storage.kubestash.com/v1alpha1 +kind: Snapshot +metadata: + creationTimestamp: "2024-09-19T08:55:01Z" + finalizers: + - kubestash.com/cleanup + generation: 1 + labels: + kubedb.com/db-version: 3.8.3 + kubestash.com/app-ref-kind: ZooKeeper + kubestash.com/app-ref-name: sample-zookeeper + kubestash.com/app-ref-namespace: demo + kubestash.com/repo-name: default-blueprint + name: default-blueprint-appbinding-sameper-frequent-backup-1726736101 + namespace: demo + ownerReferences: + - apiVersion: storage.kubestash.com/v1alpha1 + blockOwnerDeletion: true + controller: true + kind: Repository + name: default-blueprint + uid: 7cfd944f-1daa-4306-95c8-2ff7f41fd766 + resourceVersion: "1509911" + uid: f0dd0e7f-e4ec-42a4-8432-e4b44b2d0ada +spec: + appRef: + apiGroup: kubedb.com + kind: ZooKeeper + name: sample-zookeeper + namespace: demo + backupSession: appbinding-sample-zookeeper-frequent-backup-1726736101 + deletionPolicy: Delete + repository: default-blueprint + session: frequent-backup + snapshotID: 01J84QVVR9Y1ZCRKXJANQB21WE + type: FullBackup + version: v1 +status: + components: + dump: + driver: Restic + duration: 2.069889135s + integrity: true + path: repository/v1/frequent-backup/dump + phase: Succeeded + resticStats: + - hostPath: /kubestash-interim/data + id: 280cbe5908773859259f0921d89e677f4c0ab40c3e4bedee6b95ab2c9ef474e9 + size: 718 B + uploaded: 1.075 KiB + size: 1.835 KiB + conditions: + - lastTransitionTime: "2024-09-19T08:55:01Z" + message: Recent snapshot list updated successfully + reason: SuccessfullyUpdatedRecentSnapshotList + status: "True" + type: RecentSnapshotListUpdated + - lastTransitionTime: "2024-09-19T08:55:08Z" + message: Metadata uploaded to backend successfully + reason: SuccessfullyUploadedSnapshotMetadata + status: "True" + type: SnapshotMetadataUploaded + integrity: true + phase: Succeeded + size: 1.835 KiB + snapshotTime: "2024-09-19T08:55:01Z" + totalComponents: 1 + +``` + +> KubeStash uses `zk-dump-go` to perform backups of target `ZooKeeper`. Therefore, the component name for logical backups is set as `dump`. + +Now, if we navigate to the s3 bucket, we will see the backed up data stored in the `blueprint/default-blueprint/repository/v1/frequent-backup/dump` directory. KubeStash also keeps the backup for `Snapshot` YAMLs, which can be found in the `blueprint/default-blueprint/snapshots` directory. + +> Note: KubeStash stores all dumped data encrypted in the backup directory, meaning it remains unreadable until decrypted. + +## Auto-backup with custom configurations + +In this section, we are going to backup a `ZooKeeper` of `demo` namespace. We are going to use the custom configurations which will be specified in the `BackupBlueprint` CR. + +**Prepare Backup Blueprint** + +A `BackupBlueprint` allows you to specify a template for the `Repository`,`Session` or `Variables` of `BackupConfiguration` in a Kubernetes native way. + +Now, we have to create a `BackupBlueprint` CR with a blueprint for `BackupConfiguration` object. + +```yaml +apiVersion: core.kubestash.com/v1alpha1 +kind: BackupBlueprint +metadata: + name: zookeeper-customize-backup-blueprint + namespace: demo +spec: + usagePolicy: + allowedNamespaces: + from: Same + backupConfigurationTemplate: + deletionPolicy: OnDelete + backends: + - name: s3-backend + storageRef: + namespace: demo + name: s3-storage + retentionPolicy: + name: demo-retention + namespace: demo + sessions: + - name: frequent-backup + sessionHistoryLimit: 3 + scheduler: + schedule: ${schedule} + jobTemplate: + backoffLimit: 1 + repositories: + - name: ${repoName} + backend: s3-backend + directory: ${namespace}/${targetName} + encryptionSecret: + name: encrypt-secret + namespace: demo + addon: + name: zookeeper-addon + tasks: + - name: logical-backup +``` + +Note that we have used some variables (format: `${}`) in different fields. KubeStash will substitute these variables with values from the respective target’s annotations. You’re free to use any variables you like. + +Here, + +- `.spec.backupConfigurationTemplate.backends[*].storageRef` refers our earlier created `s3-storage` backupStorage. +- `.spec.backupConfigurationTemplate.sessions[*]`: + - `.schedule` defines `${schedule}` variable, which determines the time interval for the backup. + - `.repositories[*].name` defines the `${repoName}` variable, which specifies the name of the backup `Repository`. + - `.repositories[*].directory` defines two variables, `${namespace}` and `${targetName}`, which are used to determine the path where the backup will be stored. + - `.addon.tasks[*].params.args` defines `${targetedDatabase}` variable, which identifies a single database to backup. + +Let's create the `BackupBlueprint` we have shown above, + +```bash +$ kubectl apply -f https://github.com/kubedb/docs/raw/{{< param "info.version" >}}/docs/guides/zookeeper/backup/kubestash/auto-backup/examples/customize-backupblueprint.yaml +backupblueprint.core.kubestash.com/zookeeper-customize-backup-blueprint created +``` + +Now, we are ready to backup our `ZooKeeper` using few annotations. You can check available auto-backup annotations for a databases from [here](https://kubestash.com/docs/latest/concepts/crds/backupblueprint/). + +**Create Database** + +Now, we are going to create an `ZooKeeper` CR in demo namespace. + +Below is the YAML of the `ZooKeeper` object that we are going to create, + +```yaml +apiVersion: kubedb.com/v1alpha2 +kind: ZooKeeper +metadata: + name: sample-zookeeper-2 + namespace: demo + annotations: + blueprint.kubestash.com/name: zookeeper-customize-backup-blueprint + blueprint.kubestash.com/namespace: demo + variables.kubestash.com/schedule: "*/10 * * * *" + variables.kubestash.com/repoName: customize-blueprint + variables.kubestash.com/namespace: demo + variables.kubestash.com/targetName: sample-zookeeper-2 + variables.kubestash.com/targetedDatabase: zookeeper +spec: + version: "3.8.3" + adminServerPort: 8080 + replicas: 3 + storage: + resources: + requests: + storage: "1Gi" + accessModes: + - ReadWriteOnce + deletionPolicy: "WipeOut" +``` + +Notice the `metadata.annotations` field, where we have defined the annotations related to the automatic backup configuration. Specifically, we've set the `BackupBlueprint` name as `zookeeper-customize-backup-blueprint` and the namespace as `demo`. We have also provided values for the blueprint template variables, such as the backup `schedule`, `repositoryName`, `namespace`, `targetName`, and `targetedDatabase`. These annotations will be used to create a `BackupConfiguration` for this `ZooKeeper` database. + +Let's create the `ZooKeeper` we have shown above, + +```bash +$ kubectl apply -f https://github.com/kubedb/docs/raw/{{< param "info.version" >}}/docs/guides/zookeeper/backup/kubestash/auto-backup/examples/sample-zookeeper-2.yaml +zookeeper.kubedb.com/sample-zookeeper-2 created +``` + +**Verify BackupConfiguration** + +If everything goes well, KubeStash should create a `BackupConfiguration` for our ZooKeeper in demo namespace and the phase of that `BackupConfiguration` should be `Ready`. Verify the `BackupConfiguration` object by the following command, + +```bash +$ kubectl get backupconfiguration -n demo +NAME PHASE PAUSED AGE +appbinding-sample-zookeeper-2 Ready 2m50m +``` + +Now, let’s check the YAML of the `BackupConfiguration`. + +```bash +$ kubectl get backupconfiguration -n demo appbinding-sample-zookeeper-2 -o yaml +``` + +```yaml +apiVersion: core.kubestash.com/v1alpha1 +kind: BackupConfiguration +metadata: + creationTimestamp: "2024-09-19T10:37:06Z" + finalizers: + - kubestash.com/cleanup + generation: 1 + labels: + app.kubernetes.io/managed-by: kubestash.com + kubestash.com/invoker-name: zookeeper-customize-backup-blueprint + kubestash.com/invoker-namespace: demo + name: appbinding-sample-zookeeper-2 + namespace: demo + resourceVersion: "1521726" + uid: 2c80f9a0-b79e-4733-9e68-715ca6b55b93 +spec: + backends: + - name: s3-backend + retentionPolicy: + name: demo-retention + namespace: demo + storageRef: + name: s3-storage + namespace: demo + sessions: + - addon: + name: zookeeper-addon + tasks: + - name: logical-backup + name: frequent-backup + repositories: + - backend: s3-backend + directory: demo/sample-zookeeper-2 + encryptionSecret: + name: encrypt-secret + namespace: demo + name: customize-blueprint + scheduler: + jobTemplate: + backoffLimit: 1 + template: + controller: {} + metadata: {} + spec: + resources: {} + schedule: '*/10 * * * *' + sessionHistoryLimit: 3 + target: + apiGroup: kubedb.com + kind: ZooKeeper + name: sample-zookeeper-2 + namespace: demo +status: + backends: + - name: s3-backend + ready: true + retentionPolicy: + found: true + ref: + name: demo-retention + namespace: demo + storage: + phase: Ready + ref: + name: s3-storage + namespace: demo + conditions: + - lastTransitionTime: "2024-09-19T10:37:06Z" + message: Validation has been passed successfully. + reason: ResourceValidationPassed + status: "True" + type: ValidationPassed + dependencies: + - found: true + kind: Addon + name: zookeeper-addon + phase: Ready + repositories: + - name: customize-blueprint + phase: Ready + sessions: + - conditions: + - lastTransitionTime: "2024-09-19T10:37:16Z" + message: Scheduler has been ensured successfully. + reason: SchedulerEnsured + status: "True" + type: SchedulerEnsured + - lastTransitionTime: "2024-09-19T10:37:16Z" + message: Initial backup has been triggered successfully. + reason: SuccessfullyTriggeredInitialBackup + status: "True" + type: InitialBackupTriggered + name: frequent-backup + targetFound: true +``` + +Notice the `spec.backends`, `spec.sessions` and `spec.target` sections, KubeStash automatically resolved those info from the `BackupBluePrint` and created above `BackupConfiguration`. + +**Verify BackupSession:** + +KubeStash triggers an instant backup as soon as the `BackupConfiguration` is ready. After that, backups are scheduled according to the specified schedule. + +```bash +$ kubectl get backupsession -n demo -w +NAME INVOKER-TYPE INVOKER-NAME PHASE DURATION AGE +appbinding-sample-zookeeper-2-frequent-backup-1726742400 BackupConfiguration appbinding-sample-zookeeper Succeeded 58s 112s +``` + +We can see from the above output that the backup session has succeeded. Now, we are going to verify whether the backed up data has been stored in the backend. + +**Verify Backup:** + +Once a backup is complete, KubeStash will update the respective `Repository` CR to reflect the backup. Check that the repository `customize-blueprint` has been updated by the following command, + +```bash +$ kubectl get repository -n demo customize-blueprint +NAME INTEGRITY SNAPSHOT-COUNT SIZE PHASE LAST-SUCCESSFUL-BACKUP AGE +customize-blueprint true 1 806 B Ready 8m27s 9m18s +``` + +At this moment we have one `Snapshot`. Run the following command to check the respective `Snapshot` which represents the state of a backup run for an application. + +```bash +$ kubectl get snapshots -n demo -l=kubestash.com/repo-name=customize-blueprint +NAME REPOSITORY SESSION SNAPSHOT-TIME DELETION-POLICY PHASE AGE +customize-blueprint-appbinding-ser-2-frequent-backup-1726742400 customize-blueprint frequent-backup 2024-09-19T10:40:01Z Delete Succeeded 6m19s +``` + +> Note: KubeStash creates a `Snapshot` with the following labels: +> - `kubedb.com/db-version: ` +> - `kubestash.com/app-ref-kind: ` +> - `kubestash.com/app-ref-name: ` +> - `kubestash.com/app-ref-namespace: ` +> - `kubestash.com/repo-name: ` +> +> These labels can be used to watch only the `Snapshot`s related to our target Database or `Repository`. + +If we check the YAML of the `Snapshot`, we can find the information about the backed up components of the Database. + +```bash +$ kubectl get snapshots -n demo customize-blueprint-appbinding-sql-2-frequent-backup-1725597000 -oyaml +``` + +```yaml +apiVersion: storage.kubestash.com/v1alpha1 +kind: Snapshot +metadata: + creationTimestamp: "2024-09-19T10:40:01Z" + finalizers: + - kubestash.com/cleanup + generation: 1 + labels: + kubedb.com/db-version: 3.8.3 + kubestash.com/app-ref-kind: ZooKeeper + kubestash.com/app-ref-name: sample-zookeeper-2 + kubestash.com/app-ref-namespace: demo + kubestash.com/repo-name: customize-blueprint + name: customize-blueprint-appbinding-ser-2-frequent-backup-1726742400 + namespace: demo + ownerReferences: + - apiVersion: storage.kubestash.com/v1alpha1 + blockOwnerDeletion: true + controller: true + kind: Repository + name: customize-blueprint + uid: c23b7c97-f97a-4a46-81b1-74a3724d08da + resourceVersion: "1522158" + uid: 193748f3-e417-4b62-a092-be38ee1fa6b7 +spec: + appRef: + apiGroup: kubedb.com + kind: ZooKeeper + name: sample-zookeeper-2 + namespace: demo + backupSession: appbinding-sample-zookeeper-2-frequent-backup-1726742400 + deletionPolicy: Delete + repository: customize-blueprint + session: frequent-backup + snapshotID: 01J84XW407F24E7EFKJFBVS36E + type: FullBackup + version: v1 +status: + components: + dump: + driver: Restic + duration: 2.426610729s + integrity: true + path: repository/v1/frequent-backup/dump + phase: Succeeded + resticStats: + - hostPath: /kubestash-interim/data + id: 5356f92f84ad9b1ce170a99796eee91983e6df62e224d592d85fb0811a2fbb38 + size: 719 B + uploaded: 1.075 KiB + size: 1.839 KiB + conditions: + - lastTransitionTime: "2024-09-19T10:40:01Z" + message: Recent snapshot list updated successfully + reason: SuccessfullyUpdatedRecentSnapshotList + status: "True" + type: RecentSnapshotListUpdated + - lastTransitionTime: "2024-09-19T10:40:09Z" + message: Metadata uploaded to backend successfully + reason: SuccessfullyUploadedSnapshotMetadata + status: "True" + type: SnapshotMetadataUploaded + integrity: true + phase: Succeeded + size: 1.839 KiB + snapshotTime: "2024-09-19T10:40:01Z" + totalComponents: 1 + +``` + +> KubeStash uses `zk-dump-go` to perform backups of target `ZooKeeper`. Therefore, the component name for logical backups is set as `dump`. + +Now, if we navigate to the s3 bucket, we will see the backed up data stored in the `blueprint/demo/sample-zookeeper-2/repository/v1/frequent-backup/dump` directory. KubeStash also keeps the backup for `Snapshot` YAMLs, which can be found in the `blueprint/demo/sample-zookeeper-2/snapshots` directory. + +> Note: KubeStash stores all dumped data encrypted in the backup directory, meaning it remains unreadable until decrypted. + +## Cleanup + +To cleanup the resources crated by this tutorial, run the following commands, + +```bash +kubectl delete backupblueprints.core.kubestash.com -n demo zookeeper-default-backup-blueprint +kubectl delete backupblueprints.core.kubestash.com -n demo zookeeper-customize-backup-blueprint +kubectl delete retentionpolicies.storage.kubestash.com -n demo demo-retention +kubectl delete backupstorage -n demo s3-storage +kubectl delete secret -n demo s3-secret +kubectl delete secret -n demo encrypt-secret +kubectl delete zookeeper -n demo sample-zookeeper +kubectl delete zookeeper -n demo sample-zookeeper-2 +``` \ No newline at end of file diff --git a/docs/guides/zookeeper/backup/kubestash/customization/backup/multiple-backends.yaml b/docs/guides/zookeeper/backup/kubestash/customization/backup/multiple-backends.yaml new file mode 100644 index 0000000000..55ccc7b591 --- /dev/null +++ b/docs/guides/zookeeper/backup/kubestash/customization/backup/multiple-backends.yaml @@ -0,0 +1,49 @@ +apiVersion: core.kubestash.com/v1alpha1 +kind: BackupConfiguration +metadata: + name: sample-zookeeper-backup + namespace: demo +spec: + target: + apiGroup: kubedb.com + kind: ZooKeeper + namespace: demo + name: sample-zookeeper + backends: + - name: gcs-backend + storageRef: + namespace: demo + name: gcs-storage + retentionPolicy: + name: demo-retention + namespace: demo + - name: s3-backend + storageRef: + namespace: demo + name: s3-storage + retentionPolicy: + name: demo-retention + namespace: demo + sessions: + - name: frequent-backup + scheduler: + schedule: "*/5 * * * *" + jobTemplate: + backoffLimit: 1 + repositories: + - name: gcs-zookeeper-repo + backend: gcs-backend + directory: /zookeeper + encryptionSecret: + name: encrypt-secret + namespace: demo + - name: s3-zookeeper-repo + backend: s3-backend + directory: /zookeeper-copy + encryptionSecret: + name: encrypt-secret + namespace: demo + addon: + name: zookeeper-addon + tasks: + - name: logical-backup \ No newline at end of file diff --git a/docs/guides/zookeeper/backup/kubestash/customization/backup/resources-limit.yaml b/docs/guides/zookeeper/backup/kubestash/customization/backup/resources-limit.yaml new file mode 100644 index 0000000000..e08457f61e --- /dev/null +++ b/docs/guides/zookeeper/backup/kubestash/customization/backup/resources-limit.yaml @@ -0,0 +1,45 @@ +apiVersion: core.kubestash.com/v1alpha1 +kind: BackupConfiguration +metadata: + name: sample-zookeeper-backup + namespace: demo +spec: + target: + apiGroup: kubedb.com + kind: ZooKeeper + namespace: demo + name: sample-zookeeper + backends: + - name: s3-backend + storageRef: + namespace: demo + name: s3-storage + retentionPolicy: + name: demo-retention + namespace: demo + sessions: + - name: frequent-backup + scheduler: + schedule: "*/5 * * * *" + jobTemplate: + backoffLimit: 1 + repositories: + - name: s3-zookeeper-repo + backend: s3-backend + directory: /zookeeper + encryptionSecret: + name: encrypt-secret + namespace: demo + addon: + name: zookeeper-addon + jobTemplate: + spec: + resources: + requests: + cpu: "200m" + memory: "1Gi" + limits: + cpu: "200m" + memory: "1Gi" + tasks: + - name: logical-backup \ No newline at end of file diff --git a/docs/guides/zookeeper/backup/kubestash/customization/backup/specific-user.yaml b/docs/guides/zookeeper/backup/kubestash/customization/backup/specific-user.yaml new file mode 100644 index 0000000000..25ac4ab43b --- /dev/null +++ b/docs/guides/zookeeper/backup/kubestash/customization/backup/specific-user.yaml @@ -0,0 +1,41 @@ +apiVersion: core.kubestash.com/v1alpha1 +kind: BackupConfiguration +metadata: + name: sample-zookeeper-backup + namespace: demo +spec: + target: + apiGroup: kubedb.com + kind: ZooKeeper + namespace: demo + name: sample-zookeeper + backends: + - name: s3-backend + storageRef: + namespace: demo + name: s3-storage + retentionPolicy: + name: demo-retention + namespace: demo + sessions: + - name: frequent-backup + scheduler: + schedule: "*/5 * * * *" + jobTemplate: + backoffLimit: 1 + repositories: + - name: s3-zookeeper-repo + backend: s3-backend + directory: /zookeeper + encryptionSecret: + name: encrypt-secret + namespace: demo + addon: + name: zookeeper-addon + jobTemplate: + spec: + securityContext: + runAsUser: 0 + runAsGroup: 0 + tasks: + - name: logical-backup \ No newline at end of file diff --git a/docs/guides/zookeeper/backup/kubestash/customization/common/gcs-backupstorage.yaml b/docs/guides/zookeeper/backup/kubestash/customization/common/gcs-backupstorage.yaml new file mode 100644 index 0000000000..90a10f2128 --- /dev/null +++ b/docs/guides/zookeeper/backup/kubestash/customization/common/gcs-backupstorage.yaml @@ -0,0 +1,17 @@ +apiVersion: storage.kubestash.com/v1alpha1 +kind: BackupStorage +metadata: + name: gcs-storage + namespace: demo +spec: + storage: + provider: gcs + gcs: + bucket: kubestash-zk + prefix: demo + secretName: gcs-secret + usagePolicy: + allowedNamespaces: + from: All + default: false + deletionPolicy: WipeOut \ No newline at end of file diff --git a/docs/guides/zookeeper/backup/kubestash/customization/common/retentionpolicy.yaml b/docs/guides/zookeeper/backup/kubestash/customization/common/retentionpolicy.yaml new file mode 100644 index 0000000000..3af90371d1 --- /dev/null +++ b/docs/guides/zookeeper/backup/kubestash/customization/common/retentionpolicy.yaml @@ -0,0 +1,15 @@ +apiVersion: storage.kubestash.com/v1alpha1 +kind: RetentionPolicy +metadata: + name: demo-retention + namespace: demo +spec: + default: true + failedSnapshots: + last: 2 + maxRetentionPeriod: 2mo + successfulSnapshots: + last: 5 + usagePolicy: + allowedNamespaces: + from: Same \ No newline at end of file diff --git a/docs/guides/zookeeper/backup/kubestash/customization/common/s3-backupstorage.yaml b/docs/guides/zookeeper/backup/kubestash/customization/common/s3-backupstorage.yaml new file mode 100644 index 0000000000..8b09329a72 --- /dev/null +++ b/docs/guides/zookeeper/backup/kubestash/customization/common/s3-backupstorage.yaml @@ -0,0 +1,18 @@ +apiVersion: storage.kubestash.com/v1alpha1 +kind: BackupStorage +metadata: + name: s3-storage + namespace: demo +spec: + storage: + provider: s3 + s3: + endpoint: ap-south-1.linodeobjects.com + bucket: kubestash-zk + region: ap-south-1 + prefix: demo + secretName: s3-secret + usagePolicy: + allowedNamespaces: + from: All + deletionPolicy: WipeOut \ No newline at end of file diff --git a/docs/guides/zookeeper/backup/kubestash/customization/common/sample-zookeeper.yaml b/docs/guides/zookeeper/backup/kubestash/customization/common/sample-zookeeper.yaml new file mode 100644 index 0000000000..76495c1b59 --- /dev/null +++ b/docs/guides/zookeeper/backup/kubestash/customization/common/sample-zookeeper.yaml @@ -0,0 +1,16 @@ +apiVersion: kubedb.com/v1alpha2 +kind: ZooKeeper +metadata: + name: sample-zookeeper + namespace: demo +spec: + version: "3.8.3" + adminServerPort: 8080 + replicas: 4 + storage: + resources: + requests: + storage: "1Gi" + accessModes: + - ReadWriteOnce + deletionPolicy: "WipeOut" \ No newline at end of file diff --git a/docs/guides/zookeeper/backup/kubestash/customization/index.md b/docs/guides/zookeeper/backup/kubestash/customization/index.md new file mode 100644 index 0000000000..9064ac4dc7 --- /dev/null +++ b/docs/guides/zookeeper/backup/kubestash/customization/index.md @@ -0,0 +1,252 @@ +--- +title: ZooKeeper Backup Customization | KubeStash +description: Customizing ZooKeeper Backup and Restore process with KubeStash +menu: + docs_{{ .version }}: + identifier: guides-zk-backup-customization-stashv2 + name: Customizing Backup & Restore Process + parent: guides-zk-backup-stashv2 + weight: 50 +menu_name: docs_{{ .version }} +section_menu_id: guides +--- + +# Customizing Backup and Restore Process + +KubeStash provides rich customization supports for the backup and restore process to meet the requirements of various cluster configurations. This guide will show you some examples of these customizations. + +## Customizing Backup Process + +In this section, we are going to show you how to customize the backup process. Here, we are going to show some examples of providing arguments to the backup process, running the backup process as a specific user, etc. + +### Using multiple backends + +You can configure multiple backends within a single `backupConfiguration`. To back up the same data to different backends, such as S3 and GCS, declare each backend in the `.spec.backends` section. Then, reference these backends in the `.spec.sessions[*].repositories` section. + +```yaml +apiVersion: core.kubestash.com/v1alpha1 +kind: BackupConfiguration +metadata: + name: sample-zookeeper-backup + namespace: demo +spec: + target: + apiGroup: kubedb.com + kind: ZooKeeper + namespace: demo + name: sample-zookeeper + backends: + - name: gcs-backend + storageRef: + namespace: demo + name: gcs-storage + retentionPolicy: + name: demo-retention + namespace: demo + - name: s3-backend + storageRef: + namespace: demo + name: s3-storage + retentionPolicy: + name: demo-retention + namespace: demo + sessions: + - name: frequent-backup + scheduler: + schedule: "*/5 * * * *" + jobTemplate: + backoffLimit: 1 + repositories: + - name: gcs-zookeeper-repo + backend: gcs-backend + directory: /zookeeper + encryptionSecret: + name: encrypt-secret + namespace: demo + - name: s3-zookeeper-repo + backend: s3-backend + directory: /zookeeper-copy + encryptionSecret: + name: encrypt-secret + namespace: demo + addon: + name: zookeeper-addon + tasks: + - name: logical-backup +``` + +### Running backup job as a specific user + +If your cluster requires running the backup job as a specific user, you can provide `securityContext` under `addon.jobTemplate.spec.securityContext` section. The below example shows how you can run the backup job as the `root` user. + +```yaml +apiVersion: core.kubestash.com/v1alpha1 +kind: BackupConfiguration +metadata: + name: sample-zookeeper-backup + namespace: demo +spec: + target: + apiGroup: kubedb.com + kind: ZooKeeper + namespace: demo + name: sample-zookeeper + backends: + - name: s3-backend + storageRef: + namespace: demo + name: s3-storage + retentionPolicy: + name: demo-retention + namespace: demo + sessions: + - name: frequent-backup + scheduler: + schedule: "*/5 * * * *" + jobTemplate: + backoffLimit: 1 + repositories: + - name: s3-zookeeper-repo + backend: s3-backend + directory: /zookeeper + encryptionSecret: + name: encrypt-secret + namespace: demo + addon: + name: zookeeper-addon + jobTemplate: + spec: + securityContext: + runAsUser: 0 + runAsGroup: 0 + tasks: + - name: logical-backup +``` + +### Specifying Memory/CPU limit/request for the backup job + +If you want to specify the Memory/CPU limit/request for your backup job, you can specify `resources` field under `addon.jobTemplate.spec` section. + +```yaml +apiVersion: core.kubestash.com/v1alpha1 +kind: BackupConfiguration +metadata: + name: sample-zookeeper-backup + namespace: demo +spec: + target: + apiGroup: kubedb.com + kind: ZooKeeper + namespace: demo + name: sample-zookeeper + backends: + - name: s3-backend + storageRef: + namespace: demo + name: s3-storage + retentionPolicy: + name: demo-retention + namespace: demo + sessions: + - name: frequent-backup + scheduler: + schedule: "*/5 * * * *" + jobTemplate: + backoffLimit: 1 + repositories: + - name: s3-zookeeper-repo + backend: s3-backend + directory: /zookeeper + encryptionSecret: + name: encrypt-secret + namespace: demo + addon: + name: zookeeper-addon + jobTemplate: + spec: + resources: + requests: + cpu: "200m" + memory: "1Gi" + limits: + cpu: "200m" + memory: "1Gi" + tasks: + - name: logical-backup +``` + +> You can configure additional runtime settings for backup jobs within the `addon.jobTemplate.spec` sections. For further details, please refer to the [reference](https://kubestash.com/docs/latest/concepts/crds/backupconfiguration/#podtemplate-spec). + +## Customizing Restore Process + +### Running restore job as a specific user + +Similar to the backup process under the `addon.jobTemplate.spec.` you can provide `securityContext` to run the restore job as a specific user. + +```yaml +apiVersion: core.kubestash.com/v1alpha1 +kind: RestoreSession +metadata: + name: sample-zookeeper-restore + namespace: demo +spec: + target: + apiGroup: kubedb.com + kind: ZooKeeper + namespace: demo + name: restored-zookeeper + dataSource: + repository: s3-zookeeper-repo + snapshot: latest + encryptionSecret: + name: encrypt-secret + namespace: demo + addon: + name: zookeeper-addon + jobTemplate: + spec: + securityContext: + runAsUser: 0 + runAsGroup: 0 + tasks: + - name: logical-backup-restore +``` + +### Specifying Memory/CPU limit/request for the restore job + +Similar to the backup process, you can also provide `resources` field under the `addon.jobTemplate.spec.resources` section to limit the Memory/CPU for your restore job. + +```yaml +apiVersion: core.kubestash.com/v1alpha1 +kind: RestoreSession +metadata: + name: sample-zookeeper-restore + namespace: demo +spec: + target: + apiGroup: kubedb.com + kind: ZooKeeper + namespace: demo + name: restored-zookeeper + dataSource: + repository: s3-zookeeper-repo + snapshot: latest + encryptionSecret: + name: encrypt-secret + namespace: demo + addon: + name: zookeeper-addon + jobTemplate: + spec: + resources: + requests: + cpu: "200m" + memory: "1Gi" + limits: + cpu: "200m" + memory: "1Gi" + tasks: + - name: logical-backup-restore +``` + +> You can configure additional runtime settings for restore jobs within the `addon.jobTemplate.spec` sections. For further details, please refer to the [reference](https://kubestash.com/docs/latest/concepts/crds/restoresession/#podtemplate-spec). \ No newline at end of file diff --git a/docs/guides/zookeeper/backup/kubestash/customization/restore/resources-limit.yaml b/docs/guides/zookeeper/backup/kubestash/customization/restore/resources-limit.yaml new file mode 100644 index 0000000000..86fcd542f3 --- /dev/null +++ b/docs/guides/zookeeper/backup/kubestash/customization/restore/resources-limit.yaml @@ -0,0 +1,30 @@ +apiVersion: core.kubestash.com/v1alpha1 +kind: RestoreSession +metadata: + name: sample-zookeeper-restore + namespace: demo +spec: + target: + apiGroup: kubedb.com + kind: ZooKeeper + namespace: demo + name: restored-zookeeper + dataSource: + repository: s3-zookeeper-repo + snapshot: latest + encryptionSecret: + name: encrypt-secret + namespace: demo + addon: + name: zookeeper-addon + jobTemplate: + spec: + resources: + requests: + cpu: "200m" + memory: "1Gi" + limits: + cpu: "200m" + memory: "1Gi" + tasks: + - name: logical-backup-restore \ No newline at end of file diff --git a/docs/guides/zookeeper/backup/kubestash/customization/restore/specific-user.yaml b/docs/guides/zookeeper/backup/kubestash/customization/restore/specific-user.yaml new file mode 100644 index 0000000000..d2fae7a7f2 --- /dev/null +++ b/docs/guides/zookeeper/backup/kubestash/customization/restore/specific-user.yaml @@ -0,0 +1,26 @@ +apiVersion: core.kubestash.com/v1alpha1 +kind: RestoreSession +metadata: + name: sample-zookeeper-restore + namespace: demo +spec: + target: + apiGroup: kubedb.com + kind: ZooKeeper + namespace: demo + name: restored-zookeeper + dataSource: + repository: s3-zookeeper-repo + snapshot: latest + encryptionSecret: + name: encrypt-secret + namespace: demo + addon: + name: zookeeper-addon + jobTemplate: + spec: + securityContext: + runAsUser: 0 + runAsGroup: 0 + tasks: + - name: logical-backup-restore \ No newline at end of file diff --git a/docs/guides/zookeeper/backup/kubestash/logical/examples/backupconfiguration.yaml b/docs/guides/zookeeper/backup/kubestash/logical/examples/backupconfiguration.yaml new file mode 100644 index 0000000000..2d589f90bf --- /dev/null +++ b/docs/guides/zookeeper/backup/kubestash/logical/examples/backupconfiguration.yaml @@ -0,0 +1,36 @@ +apiVersion: core.kubestash.com/v1alpha1 +kind: BackupConfiguration +metadata: + name: sample-zookeeper-backup + namespace: demo +spec: + target: + apiGroup: kubedb.com + kind: ZooKeeper + name: sample-zookeeper + namespace: demo + backends: + - name: s3-backend + storageRef: + name: s3-storage + namespace: demo + retentionPolicy: + name: demo-retention + namespace: demo + sessions: + - name: frequent-backup + scheduler: + schedule: "*/5 * * * *" + jobTemplate: + backoffLimit: 1 + repositories: + - name: s3-zookeeper-repo + backend: s3-backend + directory: /zookeeper + encryptionSecret: + name: encrypt-secret + namespace: demo + addon: + name: zookeeper-addon + tasks: + - name: logical-backup \ No newline at end of file diff --git a/docs/guides/zookeeper/backup/kubestash/logical/examples/backupstorage.yaml b/docs/guides/zookeeper/backup/kubestash/logical/examples/backupstorage.yaml new file mode 100644 index 0000000000..8b09329a72 --- /dev/null +++ b/docs/guides/zookeeper/backup/kubestash/logical/examples/backupstorage.yaml @@ -0,0 +1,18 @@ +apiVersion: storage.kubestash.com/v1alpha1 +kind: BackupStorage +metadata: + name: s3-storage + namespace: demo +spec: + storage: + provider: s3 + s3: + endpoint: ap-south-1.linodeobjects.com + bucket: kubestash-zk + region: ap-south-1 + prefix: demo + secretName: s3-secret + usagePolicy: + allowedNamespaces: + from: All + deletionPolicy: WipeOut \ No newline at end of file diff --git a/docs/guides/zookeeper/backup/kubestash/logical/examples/restored-zookeeper.yaml b/docs/guides/zookeeper/backup/kubestash/logical/examples/restored-zookeeper.yaml new file mode 100644 index 0000000000..3dba4e40b4 --- /dev/null +++ b/docs/guides/zookeeper/backup/kubestash/logical/examples/restored-zookeeper.yaml @@ -0,0 +1,16 @@ +apiVersion: kubedb.com/v1alpha2 +kind: ZooKeeper +metadata: + name: restored-zookeeper + namespace: demo +spec: + version: "3.8.3" + adminServerPort: 8080 + replicas: 4 + storage: + resources: + requests: + storage: "1Gi" + accessModes: + - ReadWriteOnce + deletionPolicy: "WipeOut" \ No newline at end of file diff --git a/docs/guides/zookeeper/backup/kubestash/logical/examples/restoresession.yaml b/docs/guides/zookeeper/backup/kubestash/logical/examples/restoresession.yaml new file mode 100644 index 0000000000..51f8e06df4 --- /dev/null +++ b/docs/guides/zookeeper/backup/kubestash/logical/examples/restoresession.yaml @@ -0,0 +1,21 @@ +apiVersion: core.kubestash.com/v1alpha1 +kind: RestoreSession +metadata: + name: sample-zookeeper-restore + namespace: demo +spec: + target: + apiGroup: kubedb.com + kind: ZooKeeper + namespace: demo + name: restored-zookeeper + dataSource: + repository: s3-zookeeper-repo + snapshot: latest + encryptionSecret: + name: encrypt-secret + namespace: demo + addon: + name: zookeeper-addon + tasks: + - name: logical-backup-restore \ No newline at end of file diff --git a/docs/guides/zookeeper/backup/kubestash/logical/examples/retentionpolicy.yaml b/docs/guides/zookeeper/backup/kubestash/logical/examples/retentionpolicy.yaml new file mode 100644 index 0000000000..3af90371d1 --- /dev/null +++ b/docs/guides/zookeeper/backup/kubestash/logical/examples/retentionpolicy.yaml @@ -0,0 +1,15 @@ +apiVersion: storage.kubestash.com/v1alpha1 +kind: RetentionPolicy +metadata: + name: demo-retention + namespace: demo +spec: + default: true + failedSnapshots: + last: 2 + maxRetentionPeriod: 2mo + successfulSnapshots: + last: 5 + usagePolicy: + allowedNamespaces: + from: Same \ No newline at end of file diff --git a/docs/guides/zookeeper/backup/kubestash/logical/examples/sample-zookeeper.yaml b/docs/guides/zookeeper/backup/kubestash/logical/examples/sample-zookeeper.yaml new file mode 100644 index 0000000000..76495c1b59 --- /dev/null +++ b/docs/guides/zookeeper/backup/kubestash/logical/examples/sample-zookeeper.yaml @@ -0,0 +1,16 @@ +apiVersion: kubedb.com/v1alpha2 +kind: ZooKeeper +metadata: + name: sample-zookeeper + namespace: demo +spec: + version: "3.8.3" + adminServerPort: 8080 + replicas: 4 + storage: + resources: + requests: + storage: "1Gi" + accessModes: + - ReadWriteOnce + deletionPolicy: "WipeOut" \ No newline at end of file diff --git a/docs/guides/zookeeper/backup/kubestash/logical/index.md b/docs/guides/zookeeper/backup/kubestash/logical/index.md new file mode 100644 index 0000000000..6ff9e128fd --- /dev/null +++ b/docs/guides/zookeeper/backup/kubestash/logical/index.md @@ -0,0 +1,690 @@ +--- +title: Backup & Restore ZooKeeper | KubeStash +description: Backup ans Restore ZooKeeper using KubeStash +menu: + docs_{{ .version }}: + identifier: guides-zk-logical-backup-stashv2 + name: Logical Backup + parent: guides-zk-backup-stashv2 + weight: 20 +menu_name: docs_{{ .version }} +section_menu_id: guides +--- + +# Backup and Restore ZooKeeper using KubeStash + +KubeStash allows you to backup and restore `ZooKeeper`. It supports backups for `ZooKeeper` instances running in Standalone, and HA cluster configurations. KubeStash makes managing your `ZooKeeper` backups and restorations more straightforward and efficient. + +This guide will give you an overview how you can take backup and restore your `ZooKeeper` using `Kubestash`. + + +## Before You Begin + +- At first, you need to have a Kubernetes cluster, and the `kubectl` command-line tool must be configured to communicate with your cluster. If you do not already have a cluster, you can create one by using `Minikube` or `Kind`. +- Install `KubeDB` in your cluster following the steps [here](/docs/setup/README.md). +- Install `KubeStash` in your cluster following the steps [here](https://kubestash.com/docs/latest/setup/install/kubestash). +- Install KubeStash `kubectl` plugin following the steps [here](https://kubestash.com/docs/latest/setup/install/kubectl-plugin/). +- If you are not familiar with how KubeStash backup and restore ZooKeeper, please check the following guide [here](/docs/guides/zookeeper/backup/kubestash/overview/index.md). + +You should be familiar with the following `KubeStash` concepts: + +- [BackupStorage](https://kubestash.com/docs/latest/concepts/crds/backupstorage/) +- [BackupConfiguration](https://kubestash.com/docs/latest/concepts/crds/backupconfiguration/) +- [BackupSession](https://kubestash.com/docs/latest/concepts/crds/backupsession/) +- [RestoreSession](https://kubestash.com/docs/latest/concepts/crds/restoresession/) +- [Addon](https://kubestash.com/docs/latest/concepts/crds/addon/) +- [Function](https://kubestash.com/docs/latest/concepts/crds/function/) +- [Task](https://kubestash.com/docs/latest/concepts/crds/addon/#task-specification) + +To keep everything isolated, we are going to use a separate namespace called `demo` throughout this tutorial. + +```bash +$ kubectl create ns demo +namespace/demo created +``` + +> **Note:** YAML files used in this tutorial are stored in [docs/guides/zookeeper/backup/kubestash/logical/examples](https://github.com/kubedb/docs/raw/{{< param "info.version" >}}/docs/guides/zookeeper/backup/kubestash/logical/examples) directory of [kubedb/docs](https://github.com/kubedb/docs) repository. + + +## Backup ZooKeeper + +KubeStash supports backups for `ZooKeeper` instances across different configurations, including Standalone and HA Cluster setups. In this demonstration, we'll focus on a `ZooKeeper` using HA cluster configuration. The backup and restore process is similar for Standalone configuration. + +This section will demonstrate how to backup a `ZooKeeper`. Here, we are going to deploy a `ZooKeeper` using KubeDB. Then, we are going to backup this into a `s3` bucket. Finally, we are going to restore the backup up data into another `ZooKeeper`. + + +### Deploy Sample ZooKeeper + +Let's deploy a sample `ZooKeeper` and insert some data into it. + +**Create ZooKeeper CR:** + +Below is the YAML of a sample `ZooKeeper` CR that we are going to create for this tutorial: + +```yaml +apiVersion: kubedb.com/v1alpha2 +kind: ZooKeeper +metadata: + name: sample-zookeeper + namespace: demo +spec: + version: "3.8.3" + adminServerPort: 8080 + replicas: 3 + storage: + resources: + requests: + storage: "1Gi" + accessModes: + - ReadWriteOnce + deletionPolicy: "WipeOut" +``` + +Create the above `ZooKeeper` CR, + +```bash +$ kubectl apply -f https://github.com/kubedb/docs/raw/{{< param "info.version" >}}/docs/guides/zookeeper/backup/kubestash/logical/examples/sample-zookeeper.yaml +zookeeper.kubedb.com/sample-zookeeper created +``` + +KubeDB will deploy a `ZooKeeper` according to the above specification. It will also create the necessary `Secrets` and `Services` to access. + +Let's check if the zookeeper is ready to use, + +```bash +$ kubectl get zk -n demo sample-zookeeper +NAME VERSION STATUS AGE +sample-zookeeper 8.3.3 Ready 5m1s +``` + +The zookeeper is `Ready`. Verify that KubeDB has created a `Secret` and a `Service` for this zookeeper using the following commands, + +```bash +$ kubectl get secret -n demo +NAME TYPE DATA AGE +sample-zookeeper-auth kubernetes.io/basic-auth 2 5m20s + +$ kubectl get service -n demo -l=app.kubernetes.io/instance=sample-zookeeper +NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE +sample-zookeeper ClusterIP 10.128.65.175 2181/TCP 5m55s +sample-zookeeper-pods ClusterIP None 2181/TCP,2888/TCP,3888/TCP 5m55s +sample-zookeeper-admin-server ClusterIP 10.128.163.169 8080/TCP 5m55s +``` + +Here, we have to use service `sample-zookeeper` and secret `sample-zookeeper-auth` to connect with the zookeeper. `KubeDB` creates an [AppBinding](/docs/guides/zookeeper/concepts/appbinding.md) CR that holds the necessary information to connect with the zookeeper. + + +**Verify AppBinding:** + +Verify that the `AppBinding` has been created successfully using the following command, + +```bash +$ kubectl get appbindings -n demo +NAME TYPE VERSION AGE +sample-zookeeper kubedb.com/zookeeper 3.8.3 9m30s +``` + +Let's check the YAML of the above `AppBinding`, + +```bash +$ kubectl get appbindings -n demo sample-zookeeper -o yaml +``` + +```yaml +apiVersion: appcatalog.appscode.com/v1alpha1 +kind: AppBinding +metadata: + annotations: + kubectl.kubernetes.io/last-applied-configuration: | + {"apiVersion":"kubedb.com/v1alpha2","kind":"ZooKeeper","metadata":{"annotations":{},"name":"sample-zookeeper","namespace":"demo"},"spec":{"adminServerPort":8080,"deletionPolicy":"WipeOut","replicas":5,"storage":{"accessModes":["ReadWriteOnce"],"resources":{"requests":{"storage":"1Gi"}}},"version":"3.8.3"}} + creationTimestamp: "2024-09-12T10:40:48Z" + generation: 2 + labels: + app.kubernetes.io/component: database + app.kubernetes.io/instance: sample-zookeeper + app.kubernetes.io/managed-by: kubedb.com + app.kubernetes.io/name: zookeepers.kubedb.com + name: sample-zookeeper + namespace: demo + ownerReferences: + - apiVersion: kubedb.com/v1alpha2 + blockOwnerDeletion: true + controller: true + kind: ZooKeeper + name: sample-zookeeper + uid: 6d41f283-1a60-45a2-a529-076a09f21ec2 + resourceVersion: "481401" + uid: db007231-78f1-4ce8-8d2f-adff7d446095 +spec: + appRef: + apiGroup: kubedb.com + kind: ZooKeeper + name: sample-zookeeper + namespace: demo + clientConfig: + service: + name: sample-zookeeper + port: 2181 + scheme: http + secret: + name: sample-zookeeper-auth + type: kubedb.com/zookeeper + version: 3.8.3 +``` + +KubeStash uses the `AppBinding` CR to connect with the target database. It requires the following two fields to set in AppBinding's `.spec` section. + +Here, + +- `.spec.clientConfig.service.name` specifies the name of the Service that connects to the database. +- `.spec.secret` specifies the name of the Secret that holds necessary credentials to access the database. +- `.spec.type` specifies the types of the app that this AppBinding is pointing to. KubeDB generated AppBinding follows the following format: `/`. + + +**Insert Sample Data:** + +Now, we are going to exec into one of the database pod and create some sample data. At first, find out the database `Pod` using the following command, + +```bash +$ kubectl get pods -n demo --selector="app.kubernetes.io/instance=sample-zookeeper" +NAME READY STATUS RESTARTS AGE +sample-zookeeper-0 2/2 Running 0 16m +sample-zookeeper-1 2/2 Running 0 13m +sample-zookeeper-2 2/2 Running 0 13m +``` + +Now, let’s exec into the pod and create a directory, + +```bash +$ kubectl exec -it -n demo sample-zookeeper-0 -- sh + +Type "help" for help. + +# Check if Zookeeper server is running and healthy +$ echo ruok | nc localhost 2181 +imok + +# Create a znode named /hello-dir with the data "hello-message" +$ zkCli.sh create /hello-dir hello-messege +Connecting to localhost:2181 +... +Connection Log Messeges +... +Created /hello-dir + +# exit from the pod +/ $ exit +``` + +Now, we are ready to backup the data. + +### Prepare Backend + +We are going to store our backed up data into a `S3` bucket. We have to create a `Secret` with necessary credentials and a `BackupStorage` CR to use this backend. If you want to use a different backend, please read the respective backend configuration doc from [here](https://kubestash.com/docs/latest/guides/backends/overview/). + +**Create Secret:** + +Let's create a secret called `s3-secret` with access credentials to our desired s3 bucket, + +```bash +$ echo -n '' > AWS_ACCESS_KEY_ID +$ echo -n '' > AWS_SECRET_ACCESS_KEY +$ kubectl create secret generic -n demo s3-secret \ + --from-file=./AWS_ACCESS_KEY_ID \ + --from-file=./AWS_SECRET_ACCESS_KEY +secret/s3-secret created +``` + +**Create BackupStorage:** + +Now, create a `BackupStorage` using this secret. Below is the YAML of `BackupStorage` CR we are going to create, + +```yaml +apiVersion: storage.kubestash.com/v1alpha1 +kind: BackupStorage +metadata: + name: s3-storage + namespace: demo +spec: + storage: + provider: s3 + s3: + endpoint: ap-south-1.linodeobjects.com + bucket: kubestash-zk + region: ap-south-1 + prefix: sep4 + secretName: s3-secret + usagePolicy: + allowedNamespaces: + from: All + deletionPolicy: WipeOut +``` + +Let's create the BackupStorage we have shown above, + +```bash +$ kubectl apply -f https://github.com/kubedb/docs/raw/{{< param "info.version" >}}/docs/guides/zookeeper/backup/kubestash/logical/examples/backupstorage.yaml +backupstorage.storage.kubestash.com/s3-storage created +``` + +Now, we are ready to backup our data to our desired backend. + +**Create RetentionPolicy:** + +Now, let's create a `RetentionPolicy` to specify how the old Snapshots should be cleaned up. + +Below is the YAML of the `RetentionPolicy` object that we are going to create, + +```yaml +apiVersion: storage.kubestash.com/v1alpha1 +kind: RetentionPolicy +metadata: + name: demo-retention + namespace: demo +spec: + default: true + failedSnapshots: + last: 2 + maxRetentionPeriod: 2mo + successfulSnapshots: + last: 5 + usagePolicy: + allowedNamespaces: + from: Same +``` + +Let’s create the above `RetentionPolicy`, + +```bash +$ kubectl apply -f https://github.com/kubedb/docs/raw/{{< param "info.version" >}}/docs/guides/zookeeper/backup/kubestash/logical/examples/retentionpolicy.yaml +retentionpolicy.storage.kubestash.com/demo-retention created +``` + +### Backup + +We have to create a `BackupConfiguration` targeting respective `sample-zookeeper` ZooKeeper. Then, KubeStash will create a `CronJob` for each session to take periodic backup of that database. + +At first, we need to create a secret with a Restic password for backup data encryption. + +**Create Secret:** + +Let's create a secret called `encrypt-secret` with the Restic password, + +```bash +$ echo -n 'changeit' > RESTIC_PASSWORD +$ kubectl create secret generic -n demo encrypt-secret \ + --from-file=./RESTIC_PASSWORD +secret "encrypt-secret" created +``` + +Below is the YAML for `BackupConfiguration` CR to backup the `sample-zookeeper` that we have deployed earlier, + +```yaml +apiVersion: core.kubestash.com/v1alpha1 +kind: BackupConfiguration +metadata: + name: sample-zookeeper-backup + namespace: demo +spec: + target: + apiGroup: kubedb.com + kind: ZooKeeper + name: sample-zookeeper + namespace: demo + backends: + - name: s3-backend + storageRef: + name: s3-storage + namespace: demo + retentionPolicy: + name: demo-retention + namespace: demo + sessions: + - name: frequent-backup + scheduler: + schedule: "*/5 * * * *" + jobTemplate: + backoffLimit: 1 + repositories: + - name: s3-zookeeper-repo + backend: s3-backend + directory: /zookeeper + encryptionSecret: + name: encrypt-secret + namespace: demo + addon: + name: zookeeper-addon + tasks: + - name: logical-backup +``` + +- `.spec.sessions[*].schedule` specifies that we want to backup the database at `5 minutes` interval. +- `.spec.target` refers to the targeted `sample-zookeeper` ZooKeeper that we created earlier. + +Let's create the `BackupConfiguration` CR that we have shown above, + +```bash +$ kubectl apply -f https://github.com/kubedb/docs/raw/{{< param "info.version" >}}/docs/guides/zookeeper/kubestash/logical/examples/backupconfiguration.yaml +backupconfiguration.core.kubestash.com/sample-zookeeper-backup created +``` + +**Verify Backup Setup Successful** + +If everything goes well, the phase of the `BackupConfiguration` should be `Ready`. The `Ready` phase indicates that the backup setup is successful. Let's verify the `Phase` of the BackupConfiguration, + +```bash +$ kubectl get backupconfiguration -n demo +NAME PHASE PAUSED AGE +sample-zookeeper-backup Ready 2m50s +``` + +Additionally, we can verify that the `Repository` specified in the `BackupConfiguration` has been created using the following command, + +```bash +$ kubectl get repo -n demo +NAME INTEGRITY SNAPSHOT-COUNT SIZE PHASE LAST-SUCCESSFUL-BACKUP AGE +s3-zookeeper-repo 0 0 B Ready 3m +``` + +KubeStash keeps the backup for `Repository` YAMLs. If we navigate to the s3 bucket, we will see the `Repository` YAML stored in the `demo/zookeeper` directory. + +**Verify CronJob:** + +It will also create a `CronJob` with the schedule specified in `spec.sessions[*].scheduler.schedule` field of `BackupConfiguration` CR. + +Verify that the `CronJob` has been created using the following command, + +```bash +$ kubectl get cronjob -n demo +NAME SCHEDULE SUSPEND ACTIVE LAST SCHEDULE AGE +trigger-sample-zookeeper-backup-frequent-backup */5 * * * * 0 2m45s 3m25s +``` + +**Verify BackupSession:** + +KubeStash triggers an instant backup as soon as the `BackupConfiguration` is ready. After that, backups are scheduled according to the specified schedule. + +```bash +$ kubectl get backupsession -n demo -w +NAME INVOKER-TYPE INVOKER-NAME PHASE DURATION AGE +sample-zookeeper-backup-frequent-backup-1726572962 BackupConfiguration sample-zookeeper-backup Succeeded 7m22s +``` + +We can see from the above output that the backup session has succeeded. Now, we are going to verify whether the backed up data has been stored in the backend. + +**Verify Backup:** + +Once a backup is complete, KubeStash will update the respective `Repository` CR to reflect the backup. Check that the repository `sample-zookeeper-backup` has been updated by the following command, + +```bash +$ kubectl get repository -n demo s3-zookeeper-repo +NAME INTEGRITY SNAPSHOT-COUNT SIZE PHASE LAST-SUCCESSFUL-BACKUP AGE +s3-zookeeper-repo true 1 806 B Ready 8m27s 9m18s +``` + +At this moment we have one `Snapshot`. Run the following command to check the respective `Snapshot` which represents the state of a backup run for an application. + +```bash +$ kubectl get snapshots -n demo -l=kubestash.com/repo-name=s3-zookeeper-repo +NAME REPOSITORY SESSION SNAPSHOT-TIME DELETION-POLICY PHASE AGE +s3-zookeeper-repo-sample-zookeeper-backup-frequent-backup-1726572962 s3-zookeeper-repo frequent-backup 2024-01-23T13:10:54Z Delete Succeeded 16h +``` + +> Note: KubeStash creates a `Snapshot` with the following labels: +> - `kubestash.com/app-ref-kind: ` +> - `kubestash.com/app-ref-name: ` +> - `kubestash.com/app-ref-namespace: ` +> - `kubestash.com/repo-name: ` +> +> These labels can be used to watch only the `Snapshot`s related to our target Database or `Repository`. + +If we check the YAML of the `Snapshot`, we can find the information about the backed up components of the Database. + +```bash +$ kubectl get snapshots -n demo s3-zookeeper-repo-sample-zookeeper-backup-frequent-backup-1726572962 -oyaml +``` + +```yaml +apiVersion: storage.kubestash.com/v1alpha1 +kind: Snapshot +metadata: + creationTimestamp: "2024-09-04T11:30:00Z" + finalizers: + - kubestash.com/cleanup + generation: 1 + labels: + kubestash.com/app-ref-kind: ZooKeeper + kubestash.com/app-ref-name: sample-zookeeper + kubestash.com/app-ref-namespace: demo + kubestash.com/repo-name: s3-zookeeper-repo + annotations: + kubedb.com/db-version: "3.8.3" + name: s3-zookeeper-repo-sample-zookeeper-backup-frequent-backup-1726572962 + namespace: demo + ownerReferences: + - apiVersion: storage.kubestash.com/v1alpha1 + blockOwnerDeletion: true + controller: true + kind: Repository + name: s3-zookeeper-repo + uid: dd7e2387-227d-4b89-9489-d6255535e322 + resourceVersion: "1226490" + uid: dd7e2387-227d-4b89-9489-d6255535e322 +spec: + appRef: + apiGroup: kubedb.com + kind: ZooKeeper + name: sample-zookeeper + namespace: demo + backupSession: sample-zookeeper-backup-frequent-backup-1726572962 + deletionPolicy: Delete + repository: s3-zookeeper-repo + session: frequent-backup + snapshotID: 01J7ZW9ANMT1GAG6NP68N6Q0MJ + type: FullBackup + version: v1 +status: + components: + dump: + driver: Restic + duration: 11.526138009s + integrity: true + path: repository/v1/frequent-backup/dump + phase: Succeeded + resticStats: + - hostPath: /kubestash-interim/data + id: cd20fca1a2bf6a97e669cb9eacdc74a312a08266da92b9d687aad88841e1205d + size: 3.345 KiB + uploaded: 299 B + size: 2.202 KiB + conditions: + - lastTransitionTime: "2024-09-04T11:30:00Z" + message: Recent snapshot list updated successfully + reason: SuccessfullyUpdatedRecentSnapshotList + status: "True" + type: RecentSnapshotListUpdated + - lastTransitionTime: "2024-09-04T11:30:32Z" + message: Metadata uploaded to backend successfully + reason: SuccessfullyUploadedSnapshotMetadata + status: "True" + type: SnapshotMetadataUploaded + integrity: true + phase: Succeeded + size: 2.201 KiB + snapshotTime: "2024-09-04T11:30:00Z" + totalComponents: 1 +``` + +> KubeStash uses `zk-dump-go` to perform backups of target `ZooKeeper`. Therefore, the component name for logical backups is set as `dump`. + +Now, if we navigate to the s3 bucket, we will see the backed up data stored in the `demo/zookeeper/repository/v1/frequent-backup/dump` directory. KubeStash also keeps the backup for `Snapshot` YAMLs, which can be found in the `demo/zookeeper/snapshots` directory. + +> Note: KubeStash stores all dumped data encrypted in the backup directory, meaning it remains unreadable until decrypted. + +## Restore + +In this section, we are going to restore the database from the backup we have taken in the previous section. We are going to deploy a new database and initialize it from the backup. + +Now, we have to deploy the restored database similarly as we have deployed the original `sample-zookeeper`. However, this time there will be the following differences: + +- We are going to specify `.spec.init.waitForInitialRestore` field that tells KubeDB to wait for first restore to complete before marking this database is ready to use. + +Below is the YAML for `ZooKeeper` CR we are going deploy to initialize from backup, + +```yaml +apiVersion: kubedb.com/v1alpha2 +kind: ZooKeeper +metadata: + name: restored-zookeeper + namespace: demo +spec: + version: "3.8.3" + adminServerPort: 8080 + replicas: 3 + storage: + resources: + requests: + storage: "1Gi" + accessModes: + - ReadWriteOnce + deletionPolicy: "WipeOut" +``` + +Let's create the above database, + +```bash +$ kubectl apply -f https://github.com/kubedb/docs/raw/{{< param "info.version" >}}/docs/guides/zookeeper/backup/kubestash/logical/examples/restored-zookeeper.yaml +zookeeper.kubedb.com/restored-zookeeper created +``` + +If you check the database status, you will see it is stuck in **`Provisioning`** state. + +```bash +$ kubectl get zookeeper -n demo restored-zookeeper +NAME VERSION STATUS AGE +restored-zookeeper 3.8.3 Provisioning 61s +``` + +#### Create RestoreSession: + +Now, we need to create a `RestoreSession` CR pointing to targeted `ZooKeeper`. + +Below, is the contents of YAML file of the `RestoreSession` object that we are going to create to restore backed up data into the newly created `ZooKeeper` named `restored-zookeeper`. + +```yaml +apiVersion: core.kubestash.com/v1alpha1 +kind: RestoreSession +metadata: + name: sample-zookeeper-restore + namespace: demo +spec: + target: + apiGroup: kubedb.com + kind: ZooKeeper + namespace: demo + name: restored-zookeeper + dataSource: + repository: s3-zookeeper-repo + snapshot: latest + encryptionSecret: + name: encrypt-secret + namespace: demo + addon: + name: zookeeper-addon + tasks: + - name: logical-backup-restore +``` + +Here, + +- `.spec.target` refers to the newly created `restored-zookeeper` ZooKeeper object to where we want to restore backup data. +- `.spec.dataSource.repository` specifies the Repository object that holds the backed up data. +- `.spec.dataSource.snapshot` specifies to restore from latest `Snapshot`. + +Let's create the RestoreSession CRD object we have shown above, + +```bash +$ kubectl apply -f https://github.com/kubedb/docs/raw/{{< param "info.version" >}}/docs/guides/zookeeper/backup/kubestash/logical/examples/restoresession.yaml +restoresession.core.kubestash.com/sample-zookeeper-restore created +``` + +Once, you have created the `RestoreSession` object, KubeStash will create restore Job. Run the following command to watch the phase of the `RestoreSession` object, + +```bash +$ watch kubectl get restoresession -n demo +Every 2.0s: kubectl get restores... AppsCode-PC-03: Wed Aug 21 10:44:05 2024 +NAME REPOSITORY FAILURE-POLICY PHASE DURATION AGE +sample-zookeeper-restore gcs-zookeeper-repo Succeeded 7s 116s +``` + +The `Succeeded` phase means that the restore process has been completed successfully. + +#### Verify Restored Data: + +In this section, we are going to verify whether the desired data has been restored successfully. We are going to connect to the database server and check whether the database and the table we created earlier in the original database are restored. + +At first, check if the database has gone into **`Ready`** state by the following command, + +```bash +$ kubectl get zookeeper -n demo restored-zookeeper +NAME VERSION STATUS AGE +restored-zookeeper 8.3.1 Ready 6m31s +``` + +Now, find out the database `Pod` by the following command, + +```bash +$ kubectl get pods -n demo --selector="app.kubernetes.io/instance=restored-zookeeper" +NAME READY STATUS RESTARTS AGE +restored-zookeeper-0 2/2 Running 0 6m7s +restored-zookeeper-1 2/2 Running 0 6m1s +restored-zookeeper-2 2/2 Running 0 5m55s +``` + +Now, lets exec one of the `Pod` and verify restored data. + +```bash +$ kubectl exec -it -n demo restored-zookeeper-0 -- sh + +Type "help" for help. + +# Check if Zookeeper server is running and healthy +$ echo ruok | nc localhost 2181 +imok + +# List all znodes from the root directory +$ zkCli.sh ls / +Connecting to localhost:2181 +... +Connection Log Messeges +... +[hello-dir] + +# Verify the data stored in the /hello-dir znode +$ zkCli.sh get /hello-dir +Connecting to localhost:2181 +... +Connection Log Messeges +... +hello-messege + +# exit from the pod +/ $ exit +``` + +So, from the above output, we can see the `demo` database we had created in the original database `sample-zookeeper` has been restored in the `restored-zookeeper`. + +## Cleanup + +To cleanup the Kubernetes resources created by this tutorial, run: + +```bash +kubectl delete backupconfigurations.core.kubestash.com -n demo sample-zookeeper-backup +kubectl delete restoresessions.core.kubestash.com -n demo restore-sample-zookeeper +kubectl delete retentionpolicies.storage.kubestash.com -n demo demo-retention +kubectl delete backupstorage -n demo s3-storage +kubectl delete secret -n demo s3-secret +kubectl delete secret -n demo encrypt-secret +kubectl delete zookeeper -n demo restored-zookeeper +kubectl delete zookeeper -n demo sample-zookeeper +``` \ No newline at end of file diff --git a/docs/guides/zookeeper/backup/kubestash/overview/images/backup_overview.svg b/docs/guides/zookeeper/backup/kubestash/overview/images/backup_overview.svg new file mode 100644 index 0000000000..90e296471c --- /dev/null +++ b/docs/guides/zookeeper/backup/kubestash/overview/images/backup_overview.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/docs/guides/zookeeper/backup/kubestash/overview/images/kubedb_plus_kubestash.svg b/docs/guides/zookeeper/backup/kubestash/overview/images/kubedb_plus_kubestash.svg new file mode 100644 index 0000000000..380d92d969 --- /dev/null +++ b/docs/guides/zookeeper/backup/kubestash/overview/images/kubedb_plus_kubestash.svg @@ -0,0 +1,21 @@ + + + + + + + + + + + + + + + + + + + + + diff --git a/docs/guides/zookeeper/backup/kubestash/overview/images/restore_overview.svg b/docs/guides/zookeeper/backup/kubestash/overview/images/restore_overview.svg new file mode 100644 index 0000000000..df4ea44292 --- /dev/null +++ b/docs/guides/zookeeper/backup/kubestash/overview/images/restore_overview.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/docs/guides/zookeeper/backup/kubestash/overview/index.md b/docs/guides/zookeeper/backup/kubestash/overview/index.md new file mode 100644 index 0000000000..bf8b5428df --- /dev/null +++ b/docs/guides/zookeeper/backup/kubestash/overview/index.md @@ -0,0 +1,98 @@ +--- +title: Backup & Restore ZooKeeper Using KubeStash +menu: + docs_{{ .version }}: + identifier: guides-zk-backup-overview-stashv2 + name: Overview + parent: guides-zk-backup-stashv2 + weight: 10 +menu_name: docs_{{ .version }} +section_menu_id: guides +--- + +> New to KubeDB? Please start [here](/docs/README.md). + +{{< notice type="warning" message="Please install [KubeStash](https://kubestash.com/docs/latest/setup/install/kubestash/) to try this feature. Database backup with KubeStash is already included in the KubeDB license. So, you don't need a separate license for KubeStash." >}} + +# ZooKeeper Backup & Restore Overview + +KubeDB also uses [KubeStash](https://kubestash.com) to backup and restore databases. KubeStash by AppsCode is a cloud native data backup and recovery solution for Kubernetes workloads and databases. KubeStash utilizes [restic](https://github.com/restic/restic) to securely backup stateful applications to any cloud or on-prem storage backends (for example, S3, GCS, Azure Blob storage, Minio, NetApp, Dell EMC etc.). + +
+  KubeDB + KubeStash +
Fig: Backup KubeDB Databases Using KubeStash
+
+ +## How Backup Works + +The following diagram shows how KubeStash takes backup of a `ZooKeeper` database. Open the image in a new tab to see the enlarged version. + +
+  ZooKeeper Backup Overview +
Fig: ZooKeeper Backup Overview
+
+ +The backup process consists of the following steps: + +1. At first, a user creates a `Secret`. This secret holds the credentials to access the backend where the backed up data will be stored. + +2. Then, she creates a `BackupStorage` custom resource that specifies the backend information, along with the `Secret` containing the credentials needed to access the backend. + +3. KubeStash operator watches for `BackupStorage` custom resources. When it finds a `BackupStorage` object, it initializes the `BackupStorage` by uploading the `metadata.yaml` file to the specified backend. + +4. Next, she creates a `BackupConfiguration` custom resource that specifies the target database, addon information (including backup tasks), backup schedules, storage backends for storing the backup data, and other additional settings. + +5. KubeStash operator watches for `BackupConfiguration` objects. + +6. Once the KubeStash operator finds a `BackupConfiguration` object, it creates `Repository` with the information specified in the `BackupConfiguration`. + +7. KubeStash operator watches for `Repository` custom resources. When it finds the `Repository` object, it Initializes `Repository` by uploading `repository.yaml` file into the `spec.sessions[*].repositories[*].directory` path specified in `BackupConfiguration`. + +8. Then, it creates a `CronJob` for each session with the schedule specified in `BackupConfiguration` to trigger backup periodically. + +9. KubeStash operator triggers an instant backup as soon as the `BackupConfiguration` is ready. Backups are otherwise triggered by the `CronJob` based on the specified schedule. + +10. KubeStash operator watches for `BackupSession` custom resources. + +11. When it finds a `BackupSession` object, it creates a `Snapshot` custom resource for each `Repository` specified in the `BackupConfiguration`. + +12. Then it resolves the respective `Addon` and `Function` and prepares backup `Job` definition. + +13. Then, it creates the `Job` to backup the targeted `ZooKeeper` database. + +14. The backup `Job` reads necessary information (e.g. auth secret, port) to connect with the database from the `AppBinding` CR. It also reads backend information and access credentials from `BackupStorage` CR, Storage Secret and `Repository` path respectively. + +15. Then, the `Job` dumps the targeted `ZooKeeper` database and uploads the output to the backend. KubeStash pipes the output of dump command to uploading process. Hence, backup `Job` does not require a large volume to hold the entire dump output. + +16. After the backup process is completed, the backup `Job` updates the `status.components[dump]` field of the `Snapshot` resources with backup information of the target `ZooKeeper` database. + +## How Restore Process Works + +The following diagram shows how KubeStash restores backed up data into a `PostgreSQL` database. Open the image in a new tab to see the enlarged version. + +
+  Database Restore Overview +
Fig: ZooKeeper Restore Process Overview
+
+ +The restore process consists of the following steps: + +1. At first, a user creates a `ZooKeeper` database where the data will be restored or the user can use the same `ZooKeeper` database. + +2. Then, she creates a `RestoreSession` custom resource that specifies the target database where the backed-up data will be restored, addon information (including restore tasks), the target snapshot to be restored, the Repository containing that snapshot, and other additional settings. + +3. KubeStash operator watches for `RestoreSession` custom resources. + +4. When it finds a `RestoreSession` custom resource, it resolves the respective `Addon` and `Function` and prepares a restore `Job` definition. + +5. Then, it creates the `Job` to restore the target. + +6. The `Job` reads necessary information to connect with the database from respective `AppBinding` CR. It also reads backend information and access credentials from `Repository` CR and storage `Secret` respectively. + +7. Then, the `Job` downloads the backed up data from the backend and injects into the desired database. KubeStash pipes the downloaded data to the respective database tool to inject into the database. Hence, restore `Job` does not require a large volume to download entire backup data inside it. + +8. Finally, when the restore process is completed, the `Job` updates the `status.components[*]` field of the `RestoreSession` with restore information of the target database. + +## Next Steps + +- Backup a `ZooKeeper` database using KubeStash by the following guides from [here](/docs/guides/zookeeper/backup/kubestash/logical/index.md). \ No newline at end of file From 2971b649739a9d4b8c260fd3923945c7fbcb3da9 Mon Sep 17 00:00:00 2001 From: Rudro-25 Date: Tue, 24 Sep 2024 13:45:09 +0600 Subject: [PATCH 2/2] issue fix Signed-off-by: Rudro-25 --- docs/guides/zookeeper/backup/kubestash/auto-backup/index.md | 4 ++-- docs/guides/zookeeper/backup/kubestash/logical/index.md | 4 ++-- docs/guides/zookeeper/backup/kubestash/overview/index.md | 6 +++--- 3 files changed, 7 insertions(+), 7 deletions(-) diff --git a/docs/guides/zookeeper/backup/kubestash/auto-backup/index.md b/docs/guides/zookeeper/backup/kubestash/auto-backup/index.md index f2afb847bd..a21b7deb61 100644 --- a/docs/guides/zookeeper/backup/kubestash/auto-backup/index.md +++ b/docs/guides/zookeeper/backup/kubestash/auto-backup/index.md @@ -373,12 +373,12 @@ We can see from the above output that the backup session has succeeded. Now, we **Verify Backup:** -Once a backup is complete, KubeStash will update the respective `Repository` CR to reflect the backup. Check that the repository `sample-zookeeper-backup` has been updated by the following command, +Once a backup is complete, KubeStash will update the respective `Repository` CR to reflect the backup. Check that the repository `default-blueprint` has been updated by the following command, ```bash $ kubectl get repository -n demo default-blueprint NAME INTEGRITY SNAPSHOT-COUNT SIZE PHASE LAST-SUCCESSFUL-BACKUP AGE -default-blueprint true 3 1.559 KiB Ready 80s 7m32s +default-blueprint true 1 1.559 KiB Ready 80s 7m32s ``` At this moment we have one `Snapshot`. Run the following command to check the respective `Snapshot` which represents the state of a backup run for an application. diff --git a/docs/guides/zookeeper/backup/kubestash/logical/index.md b/docs/guides/zookeeper/backup/kubestash/logical/index.md index 6ff9e128fd..02be21a268 100644 --- a/docs/guides/zookeeper/backup/kubestash/logical/index.md +++ b/docs/guides/zookeeper/backup/kubestash/logical/index.md @@ -13,7 +13,7 @@ section_menu_id: guides # Backup and Restore ZooKeeper using KubeStash -KubeStash allows you to backup and restore `ZooKeeper`. It supports backups for `ZooKeeper` instances running in Standalone, and HA cluster configurations. KubeStash makes managing your `ZooKeeper` backups and restorations more straightforward and efficient. +KubeStash allows you to backup and restore `ZooKeeper`. KubeStash makes managing your `ZooKeeper` backups and restorations more straightforward and efficient. This guide will give you an overview how you can take backup and restore your `ZooKeeper` using `Kubestash`. @@ -48,7 +48,7 @@ namespace/demo created ## Backup ZooKeeper -KubeStash supports backups for `ZooKeeper` instances across different configurations, including Standalone and HA Cluster setups. In this demonstration, we'll focus on a `ZooKeeper` using HA cluster configuration. The backup and restore process is similar for Standalone configuration. +KubeStash supports backups for `ZooKeeper` instances across different configurations, including Standalone and ZooKeeper Ensemble setups. In this demonstration, we'll focus on a `ZooKeeper` using ZooKeeper Ensemble configuration. The backup and restore process is similar for Standalone configuration. This section will demonstrate how to backup a `ZooKeeper`. Here, we are going to deploy a `ZooKeeper` using KubeDB. Then, we are going to backup this into a `s3` bucket. Finally, we are going to restore the backup up data into another `ZooKeeper`. diff --git a/docs/guides/zookeeper/backup/kubestash/overview/index.md b/docs/guides/zookeeper/backup/kubestash/overview/index.md index bf8b5428df..e4ba11980f 100644 --- a/docs/guides/zookeeper/backup/kubestash/overview/index.md +++ b/docs/guides/zookeeper/backup/kubestash/overview/index.md @@ -36,11 +36,11 @@ The backup process consists of the following steps: 1. At first, a user creates a `Secret`. This secret holds the credentials to access the backend where the backed up data will be stored. -2. Then, she creates a `BackupStorage` custom resource that specifies the backend information, along with the `Secret` containing the credentials needed to access the backend. +2. Then, he creates a `BackupStorage` custom resource that specifies the backend information, along with the `Secret` containing the credentials needed to access the backend. 3. KubeStash operator watches for `BackupStorage` custom resources. When it finds a `BackupStorage` object, it initializes the `BackupStorage` by uploading the `metadata.yaml` file to the specified backend. -4. Next, she creates a `BackupConfiguration` custom resource that specifies the target database, addon information (including backup tasks), backup schedules, storage backends for storing the backup data, and other additional settings. +4. Next, he creates a `BackupConfiguration` custom resource that specifies the target database, addon information (including backup tasks), backup schedules, storage backends for storing the backup data, and other additional settings. 5. KubeStash operator watches for `BackupConfiguration` objects. @@ -79,7 +79,7 @@ The restore process consists of the following steps: 1. At first, a user creates a `ZooKeeper` database where the data will be restored or the user can use the same `ZooKeeper` database. -2. Then, she creates a `RestoreSession` custom resource that specifies the target database where the backed-up data will be restored, addon information (including restore tasks), the target snapshot to be restored, the Repository containing that snapshot, and other additional settings. +2. Then, he creates a `RestoreSession` custom resource that specifies the target database where the backed-up data will be restored, addon information (including restore tasks), the target snapshot to be restored, the Repository containing that snapshot, and other additional settings. 3. KubeStash operator watches for `RestoreSession` custom resources.