
Charmed MySQL K8s
- Canonical
- Databases
Channel | Revision | Published | Runs on |
---|---|---|---|
8.0/stable | 240 | 11 Mar 2025 | |
8.0/stable | 241 | 11 Mar 2025 | |
8.0/candidate | 240 | 27 Feb 2025 | |
8.0/candidate | 241 | 27 Feb 2025 | |
8.0/beta | 240 | 25 Feb 2025 | |
8.0/beta | 241 | 25 Feb 2025 | |
8.0/edge | 249 | 26 Mar 2025 | |
8.0/edge | 248 | 26 Mar 2025 |
juju deploy mysql-k8s --channel 8.0/stable
Deploy Kubernetes operators easily with Juju, the Universal Operator Lifecycle Manager. Need a Kubernetes cluster? Install MicroK8s to create a full CNCF-certified Kubernetes system in under 60 seconds.
Platform:
Note: All commands are written for juju >= v3.0
If you are using an earlier version, check the Juju 3.0 Release Notes.
How to restore backup
This is a How-To for performing a basic restore (restoring a locally made backup). To restore a backup that was made from the a different cluster, (i.e. cluster migration via restore), please reference the Cluster Migration via Restore How-To:
Prerequisites
- Scale-down to the single MySQL unit (scale it up after the backup is restored).
- Access to S3 storage
- Have configured settings for S3 storage
- Have existing backups in your S3-storage
- Point-in-time recovery requires the following MySQL K8s charm revisions:
- 248+ for arm64
- 249+ for amd64
Summary
List backups
To view the available backups to restore you can enter the command list-backups
:
juju run mysql-k8s/leader list-backups
This should show your available backups
backups: |-
backup-id | backup-type | backup-status
----------------------------------------------------
YYYY-MM-DDTHH:MM:SSZ | physical | finished
Point-in-time recovery
Point-in-time recovery (PITR) is a MySQL K8s feature that enables restorations to the database state at specific points in time. The feature is enabled by default when there’s a working relation with S3 storage.
Restore backup
To restore a backup from that list, run the restore
command and pass the backup-id
to restore:
juju run mysql-k8s/leader restore backup-id=YYYY-MM-DDTHH:MM:SSZ
Your restore will then be in progress.
However, if the user needs to restore to a specific point in time between different backups (e.g. to restore only specific transactions made between those backups), they can use the restore-to-time parameter to pass a timestamp related to the moment they want to restore.
juju run mysql-k8s/leader restore restore-to-time="YYYY-MM-DD HH:MM:SS"
Your restore will then be in progress.
It’s also possible to restore to the latest point from a specific timeline by passing the ID of a backup taken on that timeline and restore-to-time=latest when requesting a restore:
juju run mysql-k8s/leader restore restore-to-time=latest