PostgreSQL Database Operators
There are a number of PostgreSQL database Kubernetes operators available—including Crunchy PostgreSQL for Kubernetes, Zalando PostgreSQL Operator, and Percona Distribution for PostgreSQL on Kubernetes to name just a few—however, for this blog post, I will be taking the popular EnterpriseDB (EDB) PostgreSQL Operator out for a spin.
If you want to try looking at using other database operators, visit OperatorHub.io, which provides a registry of Kubernetes operators.
Before we start, let’s take a quick look at my Kubernetes environment:
data:image/s3,"s3://crabby-images/a8dca/a8dca01f80f2b97df158b64f4fea4b7ee7e6f266" alt="Kubectl"
Install Cloud Native PostgreSQL
To begin, let’s install the latest Cloud Native PostgreSQL operator:
data:image/s3,"s3://crabby-images/b829c/b829c25d5579425e46278a584a15142bc389890f" alt="Kubectl-1"
Next, let’s confirm the Operator installation:
data:image/s3,"s3://crabby-images/e7284/e7284a4915868c165d9ded238429dd2258bf7192" alt="Kubectl-2"
Create Portworx Storage Class
Use a text editor to create a file, in the example below I have set the replication factor to 2, io profile for database workloads, and asked Portworx to support volume expansions.
kind: StorageClass
apiVersion: storage.k8s.io/v1
metadata:
name: px-postgresql-sc
provisioner: kubernetes.io/portworx-volume
parameters:
repl: "2"
io_profile: "db_remote"
allowVolumeExpansion: true
Next, create a Kubernetes storage class; you can use kubectl apply, for example.
data:image/s3,"s3://crabby-images/be364/be3644cae3f5f6d8c89f1e62f8ab484c3f38ef59" alt="Kubectl-3"
Deploy PostgreSQL Cluster
Create a file named “px-postgresql-cluster.yaml”:
data:image/s3,"s3://crabby-images/2a1ed/2a1edf7b0ed27739ef575b8ee49a72f8425eabaf" alt="Kubectl-4"
Next, use kubectl to create a 3-node PostgreSQL cluster:
kubectl apply -f px-postgresql-cluster.yaml
Then, check the PostgreSQL pod status:
data:image/s3,"s3://crabby-images/65563/65563b1008fab2ac84ac56aaccb626abff55d897" alt="Kubectl-5"
Next, check the Portworx PersistentVolumeClaims:
data:image/s3,"s3://crabby-images/aff02/aff02aeb8e582cdcdb76f97a0dc6d5fb6a489616" alt="Kubectl-6"
Finally, check the PostgreSQL cluster status:
data:image/s3,"s3://crabby-images/f3340/f33409a39187ecc1801253d0ce5da1059efc7bf6" alt="Kubectl-10"
If you want additional details, you can obtain them with kubectl get cluster -o json.
Next, we want to get the cluster name:
data:image/s3,"s3://crabby-images/cb1a1/cb1a164706f5ef790b0866aa74d52a1a3cfaa049" alt="Kubectl-7"
Then, we want to get the cluster description:
data:image/s3,"s3://crabby-images/d344c/d344ce16e284c1c3b3c770bce1a3a9402cc1ffc1" alt="Kubectl-8"
The next step is to get the cluster current primary:
data:image/s3,"s3://crabby-images/9458d/9458d1157d13a08be3015d406c511ecfa4c28cc0" alt="Kubectl-9"
And finally, we want to get the cluster status:
data:image/s3,"s3://crabby-images/607f3/607f309a299c5b116c8f6224387f7d7a996175d9" alt="Kubectl-11"
Cloud Native PostgreSQL Plugin
EnterpriseDB provides a plugin for kubectl to manage a PostgreSQL cluster in Kubernetes. We can install this with:
data:image/s3,"s3://crabby-images/50135/501353194d3e909d293b5cc00effac9661022271" alt="Kubectl-12"
The cnp extension provides some additional features to kubectl:
data:image/s3,"s3://crabby-images/ac0b7/ac0b737a8eca26b40032ad7e31925f90a57e4d2c" alt="Kubectl-13"
Checking the Cloud Native PostgreSQL Status
CNP shows we are running two replicas; if the primary fails for any reason, the cluster will failover to one of them.
data:image/s3,"s3://crabby-images/e0aa9/e0aa9eea50a1a79acb42102cb04ca8ffea2541e6" alt="Kubectl-14"
Summary
In this post, I have shared how we can deploy a PostgreSQL database on Kubernetes using the EDB PostgreSQL operator and provide additional resilience using Portworx persistent storage.