Set of scripts to run Percona software in OpenShift / Kubernetes / Google Cloud Kubernetes Engine
🛑🛑🛑 Please consider using Percona XtraDB Cluster Operator
If you find a bug in Percona Docker Images or one of the related projects, you should submit a report to that project's JIRA issue tracker.
Your first step should be to search the existing set of open tickets for a similar report. If you find that someone else has already reported your problem, then you can upvote that report to increase its visibility.
If there is no existing report, submit a report following these steps:
- Sign in to Percona JIRA. You will need to create an account if you do not have one.
- Go to the Create Issue screen and select the relevant project.
- Fill in the fields of Summary, Description, Steps To Reproduce, and Affects Version to the best you can. If the bug corresponds to a crash, attach the stack trace from the logs.
An excellent resource is Elika Etemad's article on filing good bug reports..
As a general rule of thumb, please try to create bug reports that are:
- Reproducible. Include steps to reproduce the problem.
- Specific. Include as much detail as possible: which version, what environment, etc.
- Unique. Do not duplicate existing tickets.
- Scoped to a Single Bug. One bug per report.
The best way to deploy the software suite is to use propose Helm charts.
if you plan to use PMM monitoring
To start pmm-server, from helm/helm-pmm-server execute:
helm install --name monitoring ./helm/helm-pmm-server
It will expose a public IP address for the access
kubectl get service
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
monitoring-service LoadBalancer 10.31.242.113 35.233.168.128 80:32516/TCP 10m
Basic deployment
helm install --name cluster1 ./helm/helm-server
By default will deploy proxysql in from of nodes and pmm-client on each node
kubectl get service
NAME READY STATUS RESTARTS AGE
cluster1-node-0 2/2 Running 0 5m
cluster1-node-1 2/2 Running 0 4m
cluster1-node-2 2/2 Running 0 3m
cluster1-proxysql-0 2/2 Running 0 5m
monitoring-0 1/1 Running 0 1h
Connect to ProxySQL admin:
kubectl exec -it cluster1-proxysql-0 -c proxysql -- mysql -h127.0.0.1 -P6032 -uadmin -padmin
Connect to PXC via ProxySQL from a client application:
kubectl run -i --tty percona-client --image=percona:5.7 --restart=Never -- bash -il
root@percona-client:/# mysql -hcluster1-proxysql -uroot -psecr3t
helm install --name rs1 . -f values.yaml --set kind=replicaset
PMM-Server and pmm-clients require to run under user:0 (root), which is complicated in OpenShift. So the proper way to start a helm release is:
helm install --name dep1 . -f values.yaml --set pmm.enabled=false,platform=openshift
Or edit values.yaml
to change pmm.enabled
and platform
To performa backups you need
- Create a persistent backup volume. Adjust the file
backup-volume.yaml
for your needs - Execute a backup job. Example is in
xtrabackup-job.yaml
file, to perform backup run:kubectl apply -f xtrabackup-job.yaml
To start the cluster from the backup
- Make sure the cluster is not running
- Locate directory you want to restore from on the backup volume, e.g.
cluster1-node-0.cluster1-nodes-2018-06-18-17-26
- Adjust and run backup-restore job https://github.com/Percona-Lab/percona-openshift/blob/master/deploy/xtrabackup-restore-job-pxc.yaml
Before deployments you need to create passwords (secrets) which will be used to access Percona Server / Percona XtraDB Cluster. We provide file https://github.com/Percona-Lab/percona-openshift/blob/master/deploy/secret.yaml as an example. Please use your own secure passwords!
Use base64
to encode a password for secret.yaml
: echo -n 'securepassword' | base64
.
Used base64 -d
to decode a password from secret.yaml
: echo YmFja3VwX3Bhc3N3b3Jk | base64 -d
.
The proposed depoyments were tested on Kubernetes 1.9 / OpenShift Origin 3.9. The earlier versions may not work.
The deployments assume you have a default StorageClass
which will provide Persistent Volumes. If not, you need to create PersistentVolume
manually.
Deployment pxc.yaml
will create a StatefulSet with N nodes (defined in replicas: 3
)
Pay attention to the service name, defined in name: pxccluster1
TODO:
- Encrypted connections from clients to PXC Nodes
- Encrypted connections between PXC Nodes
Deployment proxysql-pxc.yaml
will create ProxySQL service and automatically configure to handle a traffic to Percona XtraDB Cluster service.
The service to handled is defined in line: - -service=pxccluster1
TODO:
- Encrypted connections from ProxySQL to PXC Nodes
The deployments support a custom MySQL config.
You can customize mysql-configmap.yaml
to add any configuration lines you may need.
Next command will create a ConfigMap: kubectl create -f mysql-configmap.yaml
. The ConfigMap must be created before any deployments.
- Provide depoloyments for PMM Server
- Configure nodes with PMM Client
- Provide a guidance how to create / restore from backups
For OpenShift replace kubectl
with oc
- List available nodes
kubectl get nodes
- List running pods
kubectl get pods
- Create deployment
kubectl create -f replica-set.yaml
- Delete deployment
kubectl delete -f replica-set.yaml
- Watch pods changing during deployment
watch kubectl get pods
- Diagnostic about a pod, in case of failure
kubectl describe po/rsnode-0
- Logs from pods
kubectl logs -f rsnode-0
- Logs from the particular container in pod
kubectl logs -f rsnode-1 -c clone-mysql
- Access to bash in container
kubectl exec rsnode-0 -it -- bash
- Access to mysql in container
kubectl exec rsnode-0 -it -- mysql -uroot -proot_password
- Access to proxysql admin
kubectl exec proxysql-0 -it -- mysql -uadmin -padmin -h127.0.0.1 -P6032
Oneliner to prepare sysbench-tpcc database
kubectl run sysbench1 --image=perconalab/sysbench --restart=Never --env="LUA_PATH=/sysbench/sysbench-tpcc/?.lua" --command -- sysbench-tpcc/tpcc.lua --mysql-host=cluster1-node-0.cluster1-nodes --mysql-user=root --mysql-password=secr3t --scale=10 --mysql-db=sbtest --db-driver=mysql --force-pk=1 prepare