I dedicated most of my spare time over the past 1 year to develop and perfecting the Triple-A Operator with mind and heart. It is a Kubernetes Operator written in GOLANG to automate the deployment and life cycle of the InnoDB Cluster on the Kubernetes platform.
Testing after testing that I did on Triple-A was very encouraging. Triple-A Operator does well as planned on top of Kubernetes, Openshift, and Oracle Container Engine for Kubernetes (OKE). Bug by bug has been resolved and I currently believe the operator is working well. Triple-A Operator can be pulled from dockerhub and ready to use.
Features on Triple-A Operator:
- Available on Public Docker Registry
- Simple concept, very easy to use
- Portable, able to run on Kubernetes / Openshift / OKE
- It’s a sidecar container that monitor the state of InnoDB Cluster
- Automatic configuration of InnoDB Cluster on Containers
- Automatic cluster membership alignment with the Statefulset's replica changes
- Automatic adding or removing members
- Network partition or pod’s failure handling
- Reboot cluster from complete outage handling
- Ad-hoc and scheduled MySQL database autobackup
This post explains Triple-A testing on OKE. I've explain the entire process of deploying MySQL InnoDB Cluster manually on OKE without Operator, here is the blog post: https://mysqlsg.blogspot.com/2021/01/oracle-container-engine-for-kubernetes.html.
I did section A and section B from the blog post, but on this test I used MySQL community docker version. Thus, I did not pull MySQL E.E docker image into my OKE Cluster.A one time setup to install TRIPLEA Operator:
1. Create a namespace (e.g. "mysql-cluster")
kubectl create ns mysql-cluster
2. Create service account
Get sample YAML from https://github.com/tripplea-sg/innodb-cluster-operator/blob/main/sample/k8s-service-account.yaml
Apply YAML: kubectl apply -f k8s-service-account.yaml
3. Create role
Get sample YAML from https://github.com/tripplea-sg/innodb-cluster-operator/blob/main/sample/k8s-role.yaml
Apply YAML: kubectl apply -f k8s-role.yaml
4. Create role binding
Get sample YAML from https://github.com/tripplea-sg/innodb-cluster-operator/blob/main/sample/k8s-role-binding.yaml
Apply YAML: kubectl apply -f k8s-role-binding.yaml
Done. Then, I used this Operator to run MySQL InnoDB Cluster.
1. Create secret to set root password (Triplea operator currently does not support complex password)
Get sample YAML from https://github.com/tripplea-sg/innodb-cluster-operator/blob/main/sample/k8s-secret.yaml
Apply YAML: kubectl apply -f k8s-secret.yaml
2. Apply InnoDB Cluster
Get sample YAML from https://github.com/tripplea-sg/innodb-cluster-operator/blob/main/sample/k8s-mysql-with-disk.yaml
Apply YAML: kubectl apply -f k8s-mysql-with-disk.yaml
InnoDB Cluster is running after waited for 2 mins!
---
AAA