MySQL Operator
MySQL Operator enables bulletproof MySQL on Kubernetes. It manages all the necessary resources for deploying and managing a highly available MySQL cluster. It provides efortless backups, while keeping the cluster highly-available.
MySQL Operator was developed by the awesome engineering team at Presslabs,
a Managed WordPress Hosting provider.
For more open-source projects, check Presslabs Code.
Goals and status
The main goals of this operator are:
- Easily deploy mysql clusters in kubernetes (cluster-per-service model)
- Friendly to devops (monitoring, availability, scalability and backup stories solved)
- Out-of-the-box backups (scheduled and on demand) and point-in-time recovery
- Support for cloning in cluster and across clusters
The operator is to be considered alpha and not suited for critical production workloads. We (Presslabs) sucessfully use it at the moment for some non-critical production workloads.
Controller deploy
To deploy this controller, use the provided helm chart, by running:
helm repo add presslabs https://presslabs.github.io/charts
helm install presslabs/mysql-operator --name mysql-operator
For more information about chart values see chart README.
This chart will deploy the controller along with an orchestrator cluster.
Deploying a cluster
tl;dr
kubectl apply -f https://raw.githubusercontent.com/presslabs/mysql-operator/master/examples/example-cluster-secret.yaml
kubectl apply -f https://raw.githubusercontent.com/presslabs/mysql-operator/master/examples/example-cluster.yaml
Before creating a cluster, you need a secret that contains the ROOT_PASSWORD
key to
init mysql with (an example for this secret can be found
at examples/example-cluster-secret.yaml). Now, to create a cluster you need
just a simple yaml file that defines it (an example can be found at examples/example-cluster.yaml:
apiVersion: mysql.presslabs.org/v1alpha1
kind: MysqlCluster
metadata:
name: my-cluster
spec:
replicas: 3
secretName: my-cluster-secret
# backupSchedule: @hourly
# backupUri: s3://bucket_name/
# backupSecretName:
For a more in depth configuration, check examples.
To list the deployed clusters use:
$ kubectl get mysql
NAME AGE
my-cluster 1m
To check cluster state use:
$ kubectl describe mysql my-cluster
...
Status:
Ready Nodes: 2
Conditions:
Last Transition Time: 2018-03-28T10:20:23Z
Message: Cluster is ready.
Reason: statefulset ready
Status: True
Type: Ready
...
Backups
Backups are stored on object storage services like S3 or google cloud storage. In order to be able to store backup, the secret defined under backupBucketSecretName
must the credentias to store those backups.
Setup backup to S3
You need to specify the backupBucketUri
for the cluster to an uri like s3://BUCKET_NAME
, and a secret with the following structure:
apiVersion: v1
kind: Secret
metadata:
name: my-cluster-backup-secret
type: Opaque
data:
AWS_ACCESS_KEY_ID: #
AWS_SECRET_KEY: #
# Optional, the AWS region to connect
# AWS_REGION: us-east1
# Optional, specify the storage class
# AWS_STORAGE_CLASS: standard
Setup backup to gcloud
You need to specify the backupBucketUri
for the cluster to an uri like gs://BUCKET_NAME
, and a secret with the following structure:
apiVersion: v1
kind: Secret
metadata:
name: my-cluster-backup-secret
type: Opaque
data:
GCS_SERVICE_ACCOUNT_JSON_KEY: #
GCS_PROJECT_ID: #
Requesting a backup
Requesting a backup is easy — you just need to create a backup object with the following structure:
apiVersion: mysql.presslabs.org/v1alpha1
kind: MysqlBackup
metadata:
name: my-cluster-backup
spec:
clusterName: my-cluster
Listing all backups
$ kubectl get mysqlbackup
NAME AGE
my-cluster-backup 1m
my-cluster-auto-backup-20180402-1604 1d
Checking the backup state:
$ kubectl describe backup my-cluster-backup
...
Status:
Completed: true
Conditions:
Last Transition Time: 2018-03-21T16:02:56Z
Message:
Reason:
Status: True
Type: Complete
...
Access orchestrator
To connect to orchestrator dashboard you have to port forward orchestrator port
3000 to your local machine by using:
kubectl port-forward mysql-operator-orchestrator-0 3000
Tech considerations
This project uses Percona Server for MySQL 5.7 because of backup improvements
(eg. backup locks), monitoring improvements and some serviceability improvements
(eg. utility user). Although we could have used MariaDB, our primary focus being WordPress,
we wanted a drop-in rather than a fork. In the future we might support MariaDB if that can
be implemented in a compatible way.
License
This project is licensed under Apache 2.0 license. Read the LICENSE file in the
top distribution directory, for the full license text.