Creating a Postgres data store on Linux on Power (ppc64le)
Install the Postgres operator and set up the data store.
- Before you begin
- Postgres Operator versions and image tags for deployment
- Installing Postgres online
- Installing Postgres offline
- Deploying and verifying Postgres (online and offline)
Before you begin
Make sure that you prepared your online and offline host to pull images from the external repository. Also, ensure that the correct Helm repo is added.
For more information, see Preparing for data store installation.
Installing Postgres online
To deploy the Zalando Postgres Operator online, complete the following steps:
-
If you are using a Red Hat OpenShift cluster, create Security Context Constraints (SCC) before you deploy the Postgres Operator.
-
Create a YAML file, for example
postgres-scc.yaml
, with the SCC resource definition.apiVersion: security.openshift.io/v1 kind: SecurityContextConstraints metadata: name: postgres-scc runAsUser: type: MustRunAs uid: 101 seLinuxContext: type: RunAsAny fsGroup: type: RunAsAny allowHostDirVolumePlugin: false allowHostNetwork: true allowHostPorts: true allowPrivilegedContainer: false allowHostIPC: true allowHostPID: true readOnlyRootFilesystem: false users: - system:serviceaccount:instana-postgres:postgres-operator - system:serviceaccount:instana-postgres:postgres-pod - system:serviceaccount:instana-postgres:default
-
Create the SCC resource.
kubectl apply -f postgres-scc.yaml
-
-
Install the Postgres Operator.
- Create the
instana-postgres
namespace.kubectl create namespace instana-postgres
- Install the Postgres Operator.
helm install postgres-operator instana/postgres-operator --create-namespace --version=1.10.0 --set configGeneral.kubernetes_use_configmaps=true --set securityContext.runAsUser=101 --namespace=instana-postgres --set image.registry=icr.io --set image.repository=ppc64le-oss/postgres-operator-ppc64le --set image.tag=v1.10.0
- Create the
-
Create a file, for example
postgres.yaml
, with thepostgresql
resource definition.apiVersion: "acid.zalan.do/v1" kind: postgresql metadata: name: postgres spec: patroni: pg_hba: - local all all trust - host all all 0.0.0.0/0 trust - local replication standby trust - hostssl replication standby all trust - hostnossl all all all reject - hostssl all all all trust dockerImage: icr.io/ppc64le-oss/spilo-ppc64le:3.0-p1 teamId: instana numberOfInstances: 3 postgresql: version: "15" parameters: # Expert section shared_buffers: "32MB" volume: size: 10Gi # Uncomment the following line to specify your own storage class, otherwise use the default. # storageClass: <REPLACE> resources: requests: cpu: 500m memory: 2Gi limits: cpu: 1000m memory: 4Gi
-
Create the
postgresql
resource. By default, Zalando creates thepostgres
user with a randomly generated password.kubectl apply -f postgres.yaml --namespace=instana-postgres
-
Retrieve the auto-generated password of the Zalando user.
kubectl get secret postgres.postgres.credentials.postgresql.acid.zalan.do -n instana-postgres --template='{{index .data.password | base64decode}}' && echo
-
Store the retrieved password in the
config.yaml
file.- Replace `<RETRIEVED_FROM_SECRET> variable value with the password that you got in the previous step.
- Replace
<username in the Postgres data store>
with the Zalando username.
datastoreConfigs: ... postgresConfigs: - user: <username in the Postgres data store> password: <RETRIEVED_FROM_SECRET> adminUser: <username in the Postgres data store> adminPassword: <RETRIEVED_FROM_SECRET> ...
-
Verify the Postgres Operator deployment.
kubectl get all -n instana-postgres
If the Postgres Operator is deployed successfully, then the result of the command is as follows:
NAME READY STATUS RESTARTS AGE pod/postgres-0 1/1 Running 0 100s pod/postgres-1 1/1 Running 0 69s pod/postgres-2 1/1 Running 0 41s pod/postgres-operator-766455c58c-ntmpf 1/1 Running 0 11m NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE service/postgres ClusterIP 192.168.1.107 <none> 5432/TCP 101s service/postgres-operator ClusterIP 192.168.1.35 <none> 8080/TCP 11m service/postgres-repl ClusterIP 192.168.1.72 <none> 5432/TCP 101s NAME READY UP-TO-DATE AVAILABLE AGE deployment.apps/postgres-operator 1/1 1 1 11m NAME DESIRED CURRENT READY AGE replicaset.apps/postgres-operator-766455c58c 1 1 1 11m NAME READY AGE statefulset.apps/postgres 3/3 103s NAME IMAGE CLUSTER-LABEL SERVICE-ACCOUNT MIN-INSTANCES AGE operatorconfiguration.acid.zalan.do/postgres-operator ghcr.io/zalando/spilo-15:3.0-p1 cluster-name postgres-pod -1 11m NAME TEAM VERSION PODS VOLUME CPU-REQUEST MEMORY-REQUEST AGE STATUS postgresql.acid.zalan.do/postgres instana 15 3 10Gi 500m 2Gi 106s Running
Installing Postgres offline
Install the Zalando Postgres Operator in an offline environment.
-
Create a YAML file, for example
postgres-scc.yaml
, with the SCC resource definition.apiVersion: security.openshift.io/v1 kind: SecurityContextConstraints metadata: name: postgres-scc runAsUser: type: MustRunAs uid: 101 seLinuxContext: type: RunAsAny fsGroup: type: RunAsAny allowHostDirVolumePlugin: false allowHostNetwork: true allowHostPorts: true allowPrivilegedContainer: false allowHostIPC: true allowHostPID: true readOnlyRootFilesystem: false users: - system:serviceaccount:instana-postgres:postgres-operator - system:serviceaccount:instana-postgres:postgres-pod - system:serviceaccount:instana-postgres:default
-
Create the SCC resource.
kubectl apply -f postgres-scc.yaml
Then, proceed with installing the Postgres operator.
If you didn't yet pull the Postgres images from the external registry when you prepared for installation, you can pull them now. Run the following commands on your bastion host. Then, copy the images to your Instana host that is in your air-gapped environment.
docker pull icr.io/ppc64le-oss/postgres-operator-ppc64le:v1.10.0
docker pull icr.io/ppc64le-oss/spilo-ppc64le:3.0-p1
Complete the following steps on your Instana host.
-
Retag the images to your internal image registry.
docker tag icr.io/ppc64le-oss/postgres-operator-ppc64le:v1.10.0 <internal-image-registry>/ppc64le-oss/postgres-operator-ppc64le:v1.10.0 docker tag icr.io/ppc64le-oss/spilo-ppc64le:3.0-p1 <internal-image-registry>/ppc64le-oss/spilo-ppc64le:3.0-p1
-
Push the images to your internal image registry on your bastion host.
docker push <internal-image-registry>/ppc64le-oss/postgres-operator-ppc64le:v1.10.0 docker push <internal-image-registry>/ppc64le-oss/spilo-ppc64le:3.0-p1
-
Create the
instana-postgres
namespace.kubectl create namespace instana-postgres
-
Optional: Create an image pull secret if your internal image registry needs authentication.
kubectl create secret docker-registry <secret_name> --namespace instana-postgres \ --docker-username=<registry_username> \ --docker-password=<registry_password> \ --docker-server=<internal-image-registry>:<internal-image-registry-port> -- docker-email=<registry_email>
-
Install the Postgres Operator.
helm install postgres-operator postgres-operator-ppc64le-1.10.0.tgz --version=1.10.0 --set configGeneral.kubernetes_use_configmaps=true --set securityContext.runAsUser=101 --namespace=instana-postgres --set image.registry=<internal-image-registry> --set image.repository=ppc64le-oss/postgres-operator-ppc64le --set image.tag=v1.10.0
-
Create a file, for example
postgres.yaml
, with thepostgresql
resource definition.apiVersion: "acid.zalan.do/v1" kind: postgresql metadata: name: postgres spec: patroni: pg_hba: - local all all trust - host all all 0.0.0.0/0 trust - local replication standby trust - hostssl replication standby all trust - hostnossl all all all reject - hostssl all all all trust dockerImage: <internal-image-registry>/ppc64le-oss/spilo-ppc64le:3.0-p1 teamId: instana numberOfInstances: 3 postgresql: version: "15" parameters: # Expert section shared_buffers: "32MB" volume: size: 10Gi # Uncomment the line below to specify your own storage class, otherwise use the default. # storageClass: <REPLACE> resources: requests: cpu: 500m memory: 2Gi limits: cpu: 1000m memory: 4Gi
-
Complete the steps in Deploying and verifying Postgres (online and offline).
Deploying and verifying Postgres (online and offline)
Complete these steps to deploy the Postgres instance and create the data store.
-
Create the
postgresql
resource.kubectl apply -f postgres.yaml --namespace=instana-postgres
-
If you used the Zalando operator, complete these steps:
-
Retrieve the auto-generated password of the Zalando user. By default, Zalando creates the
postgres
user with a randomly generated password.kubectl get secret postgres.postgres.credentials.postgresql.acid.zalan.do -n instana-postgres --template='{{index .data.password | base64decode}}' && echo
-
Store the retrieved password in the
config.yaml
file.- Replace `<RETRIEVED_FROM_SECRET> variable value with the password that you got in the previous step.
- Replace
<username in the Postgres data store>
with the Zalando username.
datastoreConfigs: ... postgresConfigs: - user: <username in the Postgres data store> password: <RETRIEVED_FROM_SECRET> adminUser: <username in the Postgres data store> adminPassword: <RETRIEVED_FROM_SECRET> ...
-
-
Verify the Postgres Operator deployment.
kubectl get all -n instana-postgres
If the Postgres Operator is deployed successfully, then the result of the command is as follows:
-
The following output is an example for Zalando operator:
NAME READY STATUS RESTARTS AGE pod/postgres-0 1/1 Running 0 100s pod/postgres-1 1/1 Running 0 69s pod/postgres-2 1/1 Running 0 41s pod/postgres-operator-766455c58c-ntmpf 1/1 Running 0 11m NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE service/postgres ClusterIP 192.168.1.107 <none> 5432/TCP 101s service/postgres-operator ClusterIP 192.168.1.35 <none> 8080/TCP 11m service/postgres-repl ClusterIP 192.168.1.72 <none> 5432/TCP 101s NAME READY UP-TO-DATE AVAILABLE AGE deployment.apps/postgres-operator 1/1 1 1 11m NAME DESIRED CURRENT READY AGE replicaset.apps/postgres-operator-766455c58c 1 1 1 11m NAME READY AGE statefulset.apps/postgres 3/3 103s NAME IMAGE CLUSTER-LABEL SERVICE-ACCOUNT MIN-INSTANCES AGE operatorconfiguration.acid.zalan.do/postgres-operator ghcr.io/zalando/spilo-15:3.0-p1 cluster-name postgres-pod -1 11m NAME TEAM VERSION PODS VOLUME CPU-REQUEST MEMORY-REQUEST AGE STATUS postgresql.acid.zalan.do/postgres instana 15 3 10Gi 500m 2Gi 106s Running
-
The following output is an example for CloudNativePG operator:
NAME READY STATUS RESTARTS AGE pod/postgres-1 1/1 Running 0 100s pod/postgres-2 1/1 Running 0 69s pod/postgres-3 1/1 Running 0 41s pod/cnpg-cloudnative-pg-64bbc87958-fqnrl 1/1 Running 0 11m NAME TYPE CLUSTER-IP EXTERNAL-IP PORT service/cnpg-webhook-service ClusterIP 172.30.66.183 <none> 443/TCP service/postgres-r ClusterIP 172.30.163.146 <none> 5432/TCP service/postgres-ro ClusterIP 172.30.226.75 <none> 5432/TCP service/postgres-rw ClusterIP 172.30.235.178 <none> 5432/TCP NAME READY UP-TO-DATE AVAILABLE AGE deployment.apps/cnpg-cloudnative-p 1/1 1 1 11m NAME DESIRED CURRENT READY AGE replicaset.apps/cnpg-cloudnative-pg-64bbc87958 1 1 1 11m
-