diff --git a/docs/guides/mariadb/pitr/_index.md b/docs/guides/mariadb/pitr/_index.md new file mode 100644 index 0000000000..cb466ee981 --- /dev/null +++ b/docs/guides/mariadb/pitr/_index.md @@ -0,0 +1,10 @@ +--- +title: Continuous Archiving and Point-in-time Recovery +menu: + docs_{{ .version }}: + identifier: pitr-mariadb + name: Point-in-time Recovery + parent: guides-mysql + weight: 42 +menu_name: docs_{{ .version }} +--- \ No newline at end of file diff --git a/docs/guides/mariadb/pitr/archiver.md b/docs/guides/mariadb/pitr/archiver.md new file mode 100644 index 0000000000..64829badbe --- /dev/null +++ b/docs/guides/mariadb/pitr/archiver.md @@ -0,0 +1,461 @@ +--- +title: Continuous Archiving and Point-in-time Recovery +menu: + docs_{{ .version }}: + identifier: pitr-mariadb-archiver + name: Overview + parent: pitr-mariadb + weight: 10 +menu_name: docs_{{ .version }} +section_menu_id: guides +--- + +> New to KubeDB? Please start [here](/docs/README.md). + +# KubeDB MariaDB - Continuous Archiving and Point-in-time Recovery + +Here, will show you how to use KubeDB to provision a MariaDB to Archive continuously and Restore point-in-time. + +## 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 [kind](https://kind.sigs.k8s.io/docs/user/quick-start/). + +Now,install `KubeDB` operator in your cluster following the steps [here](/docs/setup/README.md). + +To install `KubeStash` operator in your cluster following the steps [here](https://github.com/kubestash/installer/tree/master/charts/kubestash). + +To install `External-snapshotter` in your cluster following the steps [here](https://github.com/kubernetes-csi/external-snapshotter/tree/release-5.0). + +To keep things isolated, this tutorial uses a separate namespace called `demo` throughout this tutorial. + +```bash +$ kubectl create ns demo +namespace/demo created +``` +> Note: The yaml files used in this tutorial are stored in [docs/guides/mariadb/remote-replica/yamls](https://github.com/kubedb/docs/tree/{{< param "info.version" >}}/docs/guides/mariadb/remote-replica/yamls) folder in GitHub repository [kubedb/docs](https://github.com/kubedb/docs). + +## continuous archiving +Continuous archiving involves making regular copies (or "archives") of the MariaDB transaction log files.To ensure continuous archiving to a remote location we need prepare `BackupStorage`,`RetentionPolicy`,`MariaDBArchiver` for the KubeDB Managed MariaDB Databases. + +### BackupStorage +BackupStorage is a CR provided by KubeStash that can manage storage from various providers like GCS, S3, and more. + +```yaml +apiVersion: storage.kubestash.com/v1alpha1 +kind: BackupStorage +metadata: + name: linode-storage + namespace: demo +spec: + storage: + provider: s3 + s3: + bucket: test-archiver + endpoint: https://ap-south-1.linodeobjects.com + region: ap-south-1 + prefix: backup + secretName: storage + usagePolicy: + allowedNamespaces: + from: All + default: true + deletionPolicy: WipeOut +``` + +```bash + $ kubectl apply -f backupstorage.yaml + backupstorage.storage.kubestash.com/linode-storage created +``` + +### secrets for backup-storage +```yaml +apiVersion: v1 +kind: Secret +type: Opaque +metadata: + name: storage + namespace: demo +stringData: + AWS_ACCESS_KEY_ID: "*************26CX" + AWS_SECRET_ACCESS_KEY: "************jj3lp" + AWS_ENDPOINT: https://ap-south-1.linodeobjects.com +``` + +```bash + $ kubectl apply -f storage-secret.yaml + secret/storage created +``` + +### Retention policy +RetentionPolicy is a CR provided by KubeStash that allows you to set how long you'd like to retain the backup data. + +```yaml +apiVersion: storage.kubestash.com/v1alpha1 +kind: RetentionPolicy +metadata: + name: mariadb-retention-policy + namespace: demo +spec: + maxRetentionPeriod: "30d" + successfulSnapshots: + last: 100 + failedSnapshots: + last: 2 +``` +```bash +$ kubectl apply -f https://github.com/kubedb/docs/raw/{{< param "info.version" >}}/docs/guides/mariadb/pitr/yamls/retention-policy.yaml +retentionpolicy.storage.kubestash.com/mariadb-retention-policy created +``` + +### MariaDBArchiver +MariaDBArchiver is a custom resource(CR) provided by KubeDB for managing the archiving of MariaDB binlog files and performing volume-level backups + +```yaml +apiVersion: archiver.kubedb.com/v1alpha1 +kind: MariaDBArchiver +metadata: + name: mariadbarchiver-sample + namespace: demo +spec: + pause: false + databases: + namespaces: + from: Selector + selector: + matchLabels: + kubernetes.io/metadata.name: demo + selector: + matchLabels: + archiver: "true" + retentionPolicy: + name: mariadb-retention-policy + namespace: demo + encryptionSecret: + name: "encrypt-secret" + namespace: "demo" + fullBackup: + driver: "VolumeSnapshotter" + task: + params: + volumeSnapshotClassName: "longhorn-snapshot-vsc" + scheduler: + successfulJobsHistoryLimit: 1 + failedJobsHistoryLimit: 1 + schedule: "/30 * * * *" + sessionHistoryLimit: 2 + manifestBackup: + scheduler: + successfulJobsHistoryLimit: 1 + failedJobsHistoryLimit: 1 + schedule: "/30 * * * *" + sessionHistoryLimit: 2 + backupStorage: + ref: + name: "linode-storage" + namespace: "demo" + +``` + +### EncryptionSecret + +```yaml +apiVersion: v1 +kind: Secret +type: Opaque +metadata: + name: encrypt-secret + namespace: demo +stringData: + RESTIC_PASSWORD: "changeit" +``` + +```bash + $ kubectl create -f https://github.com/kubedb/docs/raw/{{< param "info.version" >}}/docs/guides/mariadb/pirt/yamls/mariadbarchiver.yaml + mariadbarchiver.archiver.kubedb.com/mariadbarchiver-sample created + $ kubectl create -f https://github.com/kubedb/docs/raw/{{< param "info.version" >}}/docs/guides/mariadb/pirt/yamls/encryptionSecret.yaml +``` + +## Ensure volumeSnapshotClass + +```bash +$ kubectl get volumesnapshotclasses +NAME DRIVER DELETIONPOLICY AGE +longhorn-snapshot-vsc driver.longhorn.io Delete 7d22h + +``` +If not any, try using `longhorn` or any other [volumeSnapshotClass](https://kubernetes.io/docs/concepts/storage/volume-snapshot-classes/). +```yaml +kind: VolumeSnapshotClass +apiVersion: snapshot.storage.k8s.io/v1 +metadata: + name: longhorn-snapshot-vsc +driver: driver.longhorn.io +deletionPolicy: Delete +parameters: + type: snap + +``` + +```bash +$ helm install longhorn longhorn/longhorn --namespace longhorn-system --create-namespace + +$ kubectl apply -f volumesnapshotclass.yaml + volumesnapshotclass.snapshot.storage.k8s.io/longhorn-snapshot-vsc unchanged +``` + +# Deploy MariaDB +So far we are ready with setup for continuously archive MariaDB, We deploy a mariadb referring the MariaDB archiver object.To properly configure MariaDB for archiving, you need to pass specific arguments to the MariaDB container in the `spec.podTemplate.containers["mariadb"].args` field. Below is an example of a YAML configuration for a MariaDB instance managed by KubeDB, with archiving enabled. + +```yaml +apiVersion: kubedb.com/v1 +kind: MariaDB +metadata: + name: mariadb + namespace: demo + labels: + archiver: "true" +spec: + version: "11.1.3" + replicas: 3 + storageType: Durable + storage: + storageClassName: "longhorn" + accessModes: + - ReadWriteOnce + resources: + requests: + storage: 10Gi + archiver: + ref: + name: mariadbarchiver-sample + namespace: demo + deletionPolicy: WipeOut + podTemplate: + spec: + containers: + - name: mariadb + args: + - "--log-bin" + - "--log-slave-updates" + - "--wsrep-gtid-mode=ON" +``` + + +```bash +$ kubectl get pod -n demo +NAME READY STATUS RESTARTS AGE +mariadb-0 2/2 Running 0 28h +mariadb-1 2/2 Running 0 28h +mariadb-2 2/2 Running 0 28h +mariadb-backup-config-full-backup-1703680982-vqf7c 0/1 Completed 0 28h +mariadb-backup-config-manifest-1703680982-62x97 0/1 Completed 0 28h +mariadb-sidekick 1/1 Running 0 28h +``` + +`mariadb-sidekick` is responsible for uploading binlog files + +`mariadb-backup-config-full-backup-1703680982-vqf7c` are the pod of volumes levels backups for MariaDB. + +`mariadb-backup-config-manifest-1703680982-62x97` are the pod of the manifest backup related to MariaDB object + +### validate BackupConfiguration and VolumeSnapshots + +```bash + +$ kubectl get backupconfigurations -n demo + +NAME PHASE PAUSED AGE +mariadb-backup-config Ready 2m43s + +$ kubectl get backupsession -n demo +NAME INVOKER-TYPE INVOKER-NAME PHASE DURATION AGE +mariadb-backup-config-full-backup-1702388088 BackupConfiguration mariadb-backup-config Succeeded 74s +mariadb-backup-config-manifest-1702388088 BackupConfiguration mariadb-backup-config Succeeded 74s + +kubectl get volumesnapshots -n demo +NAME READYTOUSE SOURCEPVC SOURCESNAPSHOTCONTENT RESTORESIZE SNAPSHOTCLASS SNAPSHOTCONTENT CREATIONTIME AGE +mariadb-1702388096 true data-mariadb-1 1Gi longhorn-snapshot-vsc snapcontent-735e97ad-1dfa-4b70-b416-33f7270d792c 2m5s 2m5s +``` + +## data insert and switch wal +After each and every wal switch the wal files will be uploaded to backup storage + +```bash +$ kubectl exec -it -n demo mariadb-0 -- bash + +bash-4.4$ mariadb -uroot -p$MYSQL_ROOT_PASSWORD + +mariadb> create database hello; + +mariadb> use hello; + +mariadb> CREATE TABLE `demo_table`( + -> `id` BIGINT(20) NOT NULL, + -> `name` VARCHAR(255) DEFAULT NULL, + -> PRIMARY KEY (`id`) + -> ); + +mariadb> INSERT INTO `demo_table` (`id`, `name`) + -> VALUES + -> (1, 'John'), + -> (2, 'Jane'), + -> (3, 'Bob'), + -> (4, 'Alice'), + -> (5, 'Charlie'), + -> (6, 'Diana'), + -> (7, 'Eve'), + -> (8, 'Frank'), + -> (9, 'Grace'), + -> (10, 'Henry'); + +mariadb> select now(); ++---------------------+ +| now() | ++---------------------+ +| 2023-12-28 17:10:54 | ++---------------------+ ++---------------------+ + +mariadb> select count(*) from demo_table; ++----------+ +| count(*) | ++----------+ +| 10 | ++----------+ + +``` + +> At this point We have 10 rows in our newly created table `demo_table` on database `hello` + +## Point-in-time Recovery +Point-In-Time Recovery allows you to restore a MariaDB database to a specific point in time using the archived transaction logs. This is particularly useful in scenarios where you need to recover to a state just before a specific error or data corruption occurred. +Let's say accidentally our dba drops the the table tab_1 and we want to restore. + +```bash +$ kubectl exec -it -n demo mariadb-0 -- bash + +mariadb> drop table demo_table; + +mariadb> flush logs; + +``` +We can't restore from a full backup since at this point no full backup was perform. so we can choose a specific time in which time we want to restore.We can get the specfice time from the wal that archived in the backup storage . Go to the binlog file and find where to store. You can parse binlog-files using `mariadbbinlog`. + + +For the demo I will use the previous time we get form `select now()` + +```bash +mariadb> select now(); ++---------------------+ +| now() | ++---------------------+ +| 2023-12-28 17:10:54 | ++---------------------+ +``` +### Restore MariaDB + +```yaml +apiVersion: kubedb.com/v1 +kind: MariaDB +metadata: + name: restore-mariadb + namespace: demo +spec: + init: + archiver: + encryptionSecret: + name: encrypt-secret + namespace: demo + fullDBRepository: + name: mariadb-full + namespace: demo + recoveryTimestamp: "2023-12-28T17:10:54Z" + version: "11.1.3" + replicas: 3 + storageType: Durable + storage: + storageClassName: "longhorn" + accessModes: + - ReadWriteOnce + resources: + requests: + storage: 10Gi + deletionPolicy: WipeOut + podTemplate: + spec: + containers: + - name: mariadb + args: + - "--log-bin" + - "--log-slave-updates" + - "--wsrep-gtid-mode=ON" + +``` + +```bash +$ kubectl apply -f restore.yaml +mariadb.kubedb.com/restore-mariadb created +``` + +**check for Restored MariaDB** + +```bash +$ kubectl get pod -n demo +restore-mariadb-0 1/1 Running 0 44s +restore-mariadb-1 1/1 Running 0 42s +restore-mariadb-2 1/1 Running 0 41s +restore-mariadb-restorer-z4brz 0/2 Completed 0 113s +restore-mariadb-restoresession-lk6jq 0/1 Completed 0 2m6s + +``` + +```bash +$ kubectl get mariadb -n demo +NAME VERSION STATUS AGE +mariadb 11.1.3 Ready 28h +restore-mariadb 11.1.3 Ready 5m37s +``` + +**Validating data on Restored MariaDB** + +```bash +$ kubectl exec -it -n demo restore-mariadb-0 -- bash +bash-4.4$ mariadb -uroot -p$MYSQL_ROOT_PASSWORD + +mariadb> use hello + +mariadb> select count(*) from demo_table; ++----------+ +| count(*) | ++----------+ +| 10 | ++----------+ +1 row in set (0.00 sec) + +``` + +**so we are able to successfully recover from a disaster** + +## Cleaning up + +To cleanup the Kubernetes resources created by this tutorial, run: + +```bash +$ kubectl delete -n demo mariadb/mariadb +$ kubectl delete -n demo mariadb/restore-mariadb +$ kubectl delete -n demo backupstorage +$ kubectl delete -n demo mariadbarchiver +$ kubectl delete ns demo +``` + +## Next Steps + +- Learn about [backup and restore](/docs/guides/mariadb/backup/overview/index.md) MariaDB database using Stash. +- Learn about initializing [MariaDB with Script](/docs/guides/mariadb/initialization/script_source.md). +- Learn about [custom MariaDBVersions](/docs/guides/mariadb/custom-versions/setup.md). +- Want to setup MariaDB cluster? Check how to [configure Highly Available MariaDB Cluster](/docs/guides/mariadb/clustering/ha_cluster.md) +- Monitor your MariaDB database with KubeDB using [built-in Prometheus](/docs/guides/mariadb/monitoring/using-builtin-prometheus.md). +- Monitor your MariaDB database with KubeDB using [Prometheus operator](/docs/guides/mariadb/monitoring/using-prometheus-operator.md). +- Detail concepts of [MariaDB object](/docs/guides/mariadb/concepts/mariadb.md). +- Use [private Docker registry](/docs/guides/mariadb/private-registry/using-private-registry.md) to deploy MariaDB with KubeDB. +- Want to hack on KubeDB? Check our [contribution guidelines](/docs/CONTRIBUTING.md). \ No newline at end of file diff --git a/docs/guides/mariadb/pitr/yamls/backupstorage.yaml b/docs/guides/mariadb/pitr/yamls/backupstorage.yaml new file mode 100644 index 0000000000..bf261ab175 --- /dev/null +++ b/docs/guides/mariadb/pitr/yamls/backupstorage.yaml @@ -0,0 +1,19 @@ +apiVersion: storage.kubestash.com/v1alpha1 +kind: BackupStorage +metadata: + name: linode-storage + namespace: demo +spec: + storage: + provider: s3 + s3: + bucket: test-archiver + endpoint: https://ap-south-1.linodeobjects.com + region: ap-south-1 + prefix: backup + secretName: storage + usagePolicy: + allowedNamespaces: + from: All + default: true + deletionPolicy: WipeOut \ No newline at end of file diff --git a/docs/guides/mariadb/pitr/yamls/encryptionSecret.yaml b/docs/guides/mariadb/pitr/yamls/encryptionSecret.yaml new file mode 100644 index 0000000000..4eb0c25bdb --- /dev/null +++ b/docs/guides/mariadb/pitr/yamls/encryptionSecret.yaml @@ -0,0 +1,8 @@ +apiVersion: v1 +kind: Secret +type: Opaque +metadata: + name: encrypt-secret + namespace: demo +stringData: + RESTIC_PASSWORD: "changeit" diff --git a/docs/guides/mariadb/pitr/yamls/mariadb.yaml b/docs/guides/mariadb/pitr/yamls/mariadb.yaml new file mode 100644 index 0000000000..8698725585 --- /dev/null +++ b/docs/guides/mariadb/pitr/yamls/mariadb.yaml @@ -0,0 +1,31 @@ +apiVersion: kubedb.com/v1 +kind: MariaDB +metadata: + name: mariadb + namespace: demo + labels: + archiver: "true" +spec: + version: "11.1.3" + replicas: 3 + storageType: Durable + storage: + storageClassName: "longhorn" + accessModes: + - ReadWriteOnce + resources: + requests: + storage: 10Gi + archiver: + ref: + name: mariadbarchiver-sample + namespace: demo + deletionPolicy: WipeOut + podTemplate: + spec: + containers: + - name: mariadb + args: + - "--log-bin" + - "--log-slave-updates" + - "--wsrep-gtid-mode=ON" \ No newline at end of file diff --git a/docs/guides/mariadb/pitr/yamls/mariadbarchiver.yaml b/docs/guides/mariadb/pitr/yamls/mariadbarchiver.yaml new file mode 100644 index 0000000000..f192bac752 --- /dev/null +++ b/docs/guides/mariadb/pitr/yamls/mariadbarchiver.yaml @@ -0,0 +1,42 @@ +apiVersion: archiver.kubedb.com/v1alpha1 +kind: MySQLArchiver +metadata: + name: mariadbarchiver-sample + namespace: demo +spec: + pause: false + databases: + namespaces: + from: Selector + selector: + matchLabels: + kubernetes.io/metadata.name: demo + selector: + matchLabels: + archiver: "true" + retentionPolicy: + name: mariadb-retention-policy + namespace: demo + encryptionSecret: + name: "encrypt-secret" + namespace: "demo" + fullBackup: + driver: "VolumeSnapshotter" + task: + params: + volumeSnapshotClassName: "longhorn-snapshot-vsc" + scheduler: + successfulJobsHistoryLimit: 1 + failedJobsHistoryLimit: 1 + schedule: "/30 * * * *" + sessionHistoryLimit: 2 + manifestBackup: + scheduler: + successfulJobsHistoryLimit: 1 + failedJobsHistoryLimit: 1 + schedule: "/30 * * * *" + sessionHistoryLimit: 2 + backupStorage: + ref: + name: "linode-storage" + namespace: "demo" \ No newline at end of file diff --git a/docs/guides/mariadb/pitr/yamls/retentionPolicy.yaml b/docs/guides/mariadb/pitr/yamls/retentionPolicy.yaml new file mode 100644 index 0000000000..6934450419 --- /dev/null +++ b/docs/guides/mariadb/pitr/yamls/retentionPolicy.yaml @@ -0,0 +1,11 @@ +apiVersion: storage.kubestash.com/v1alpha1 +kind: RetentionPolicy +metadata: + name: mariadb-retention-policy + namespace: demo +spec: + maxRetentionPeriod: "30d" + successfulSnapshots: + last: 100 + failedSnapshots: + last: 2 diff --git a/docs/guides/mariadb/pitr/yamls/voluemsnapshotclass.yaml b/docs/guides/mariadb/pitr/yamls/voluemsnapshotclass.yaml new file mode 100644 index 0000000000..1a67906612 --- /dev/null +++ b/docs/guides/mariadb/pitr/yamls/voluemsnapshotclass.yaml @@ -0,0 +1,8 @@ +kind: VolumeSnapshotClass +apiVersion: snapshot.storage.k8s.io/v1 +metadata: + name: longhorn-snapshot-vsc +driver: driver.longhorn.io +deletionPolicy: Delete +parameters: + type: snap \ No newline at end of file