diff --git a/docs/examples/pgbouncer/quickstart/pgbouncer-server.yaml b/docs/examples/pgbouncer/quickstart/pgbouncer-server.yaml index 0464d07156..92e4097aef 100644 --- a/docs/examples/pgbouncer/quickstart/pgbouncer-server.yaml +++ b/docs/examples/pgbouncer/quickstart/pgbouncer-server.yaml @@ -4,15 +4,16 @@ metadata: name: pgbouncer-server namespace: demo spec: - version: "1.17.0" + version: "1.18.0" replicas: 1 databases: - - alias: "postgres" - databaseName: "postgres" - databaseRef: - name: "quick-postgres" - namespace: demo + - alias: "postgres" + databaseName: "postgres" + databaseRef: + name: "quick-postgres" + namespace: demo connectionPool: + port: 5432 maxClientConnections: 20 reservePoolSize: 5 - terminationPolicy: WipeOut + terminationPolicy: Delete diff --git a/docs/guides/pgbouncer/concepts/pgbouncer.md b/docs/guides/pgbouncer/concepts/pgbouncer.md index e5a684b0cd..ed57a68e86 100644 --- a/docs/guides/pgbouncer/concepts/pgbouncer.md +++ b/docs/guides/pgbouncer/concepts/pgbouncer.md @@ -33,7 +33,7 @@ metadata: name: pgbouncer-server namespace: demo spec: - version: "1.17.0" + version: "1.18.0" replicas: 2 databases: - alias: "postgres" @@ -41,11 +41,6 @@ spec: databaseRef: name: "quick-postgres" namespace: demo - - alias: "tmpdb" - databaseName: "mydb" - databaseRef: - name: "quick-postgres" - namespace: demo connectionPool: maxClientConnections: 20 reservePoolSize: 5 @@ -62,7 +57,7 @@ spec: `spec.version` is a required field that specifies the name of the [PgBouncerVersion](/docs/guides/pgbouncer/concepts/catalog.md) crd where the docker images are specified. Currently, when you install KubeDB, it creates the following `PgBouncerVersion` resources, -- `1.17.0` +- `1.18.0` ### spec.replicas @@ -75,15 +70,10 @@ spec: - `spec.databases.alias`: specifies an alias for the target database located in a postgres server specified by an appbinding. - `spec.databases.databaseName`: specifies the name of the target database. - `spec.databases.databaseRef`: specifies the name and namespace of the AppBinding that contains the path to a PostgreSQL server where the target database can be found. -- `spec.databases.databaseSecretRef` (optional): points to a secret that contains the credentials (username and password) of an existing user of this database. It is used to bind a single user to this specific database connection.. ConnectionPool is used to configure pgbouncer connection-pool. All the fields here are accompanied by default values and can be left unspecified if no customisation is required by the user. -- `spec.connectionPool.listenPort`: specifies the port on which pgbouncer should listen to connect with clients. The default is 5432. - -- `spec.connectionPool.listenAddress`: specifies the adress from which pgbouncer should allow client connection from. The default is `*` (all addresses). - -- `spec.connectionPool.adminUsers`: specifies the values of admin_users. Comma seperated names of admin users are listed here. +- `spec.connectionPool.port`: specifies the port on which pgbouncer should listen to connect with clients. The default is 5432. - `spec.connectionPool.poolMode`: specifies the value of pool_mode. Specifies when a server connection can be reused by other clients. @@ -145,9 +135,6 @@ ConnectionPool is used to configure pgbouncer connection-pool. All the fields he - `spec.connectionPool.authType`: specifies how to authenticate users. PgBouncer supports several authentication methods including pam, md5, scram-sha-256, trust , or any. However hba, and cert are not supported. -- `spec.connectionPool.authUser`: looks up any user not specified in auth_file from pg_shadow. - Default: not set. - - `spec.connectionPool.IgnoreStartupParameters`: specifies comma-separated startup parameters that pgbouncer knows are handled by admin and it can ignore them. ### spec.monitor diff --git a/docs/guides/pgbouncer/quickstart/quickstart.md b/docs/guides/pgbouncer/quickstart/quickstart.md index cb9f8483db..75ee7cb09e 100644 --- a/docs/guides/pgbouncer/quickstart/quickstart.md +++ b/docs/guides/pgbouncer/quickstart/quickstart.md @@ -19,7 +19,7 @@ section_menu_id: guides This tutorial will show you how to use KubeDB to run a PgBouncer.
- +
## Before You Begin @@ -46,13 +46,15 @@ When you have installed KubeDB, it has created `PgBouncerVersion` crd for all su ```bash $ kubectl get pgbouncerversions - NAME VERSION PGBOUNCER_IMAGE DEPRECATED AGE - 1.17.0 1.17.0 kubedb/pgbouncer:1.17.0 2d23h + NAME VERSION PGBOUNCER_IMAGE DEPRECATED AGE + 1.17.0 1.17.0 ghcr.io/kubedb/pgbouncer:1.17.0 22h + 1.18.0 1.18.0 ghcr.io/kubedb/pgbouncer:1.18.0 22h + ``` Notice the `DEPRECATED` column. Here, `true` means that this PgBouncerVersion is deprecated for current KubeDB version. KubeDB will not work for deprecated PgBouncerVersion. -In this tutorial, we will use `1.17.0` PgBouncerVersion crd to create PgBouncer. To know more about what `PgBouncerVersion` crd is, please visit [here](/docs/guides/pgbouncer/concepts/catalog.md). You can also see supported PgBouncerVersion [here](/docs/guides/pgbouncer/README.md#supported-pgbouncerversion-crd). +In this tutorial, we will use `1.18.0` PgBouncerVersion crd to create PgBouncer. To know more about what `PgBouncerVersion` crd is, please visit [here](/docs/guides/pgbouncer/concepts/catalog.md). You can also see supported PgBouncerVersion [here](/docs/guides/pgbouncer/README.md#supported-pgbouncerversion-crd). ## Get PostgreSQL Server ready @@ -74,11 +76,11 @@ $ kubectl get secrets -n demo quick-postgres-auth -o yaml apiVersion: v1 data: - password: WkZvcGVMbndrU2ZfZjVZcw== + password: Um9YKkw4STs4Ujd2MzJ0aQ== username: cG9zdGdyZXM= kind: Secret metadata: - creationTimestamp: "2022-06-01T11:51:32Z" + creationTimestamp: "2023-10-10T11:03:47Z" labels: app.kubernetes.io/component: database app.kubernetes.io/instance: quick-postgres @@ -86,8 +88,8 @@ metadata: app.kubernetes.io/name: postgreses.kubedb.com name: quick-postgres-auth namespace: demo - resourceVersion: "195262" - uid: abe166bc-a1da-40d9-8a5e-996a8f5d6246 + resourceVersion: "5527" + uid: 7f865964-58dd-40e7-aca6-d2a3010732c3 type: kubernetes.io/basic-auth ``` @@ -96,7 +98,7 @@ For the purpose of this tutorial, we will need to extract the username and passw ```bash $ kubectl get secrets -n demo quick-postgres-auth -o jsonpath='{.data.\password}' | base64 -d -ZFopeLnwkSf_f5Ys⏎ +RoX*L8I;8R7v32ti⏎ $ kubectl get secrets -n demo quick-postgres-auth -o jsonpath='{.data.\username}' | base64 -d postgres⏎ @@ -110,12 +112,12 @@ Forwarding from 127.0.0.1:5432 -> 5432 Forwarding from [::1]:5432 -> 5432 ``` -With that done , we should now be able to connect to `postgres` database using username `postgres`, and password `ZFopeLnwkSf_f5Ys`. +With that done , we should now be able to connect to `postgres` database using username `postgres`, and password `RoX*L8I;8R7v32ti`. ```bash -$ export PGPASSWORD=ZFopeLnwkSf_f5Ys +$ export PGPASSWORD='RoX*L8I;8R7v32ti' $ psql --host=localhost --port=5432 --username=postgres postgres -psql (14.1 (Ubuntu 14.1-2.pgdg20.04+1), server 13.2) +psql (14.9 (Ubuntu 14.9-0ubuntu0.22.04.1), server 13.2) Type "help" for help. postgres=# @@ -163,7 +165,7 @@ metadata: name: pgbouncer-server namespace: demo spec: - version: "1.17.0" + version: "1.18.0" replicas: 1 databases: - alias: "postgres" @@ -172,6 +174,7 @@ spec: name: "quick-postgres" namespace: demo connectionPool: + port: 5432 maxClientConnections: 20 reservePoolSize: 5 terminationPolicy: Delete @@ -200,7 +203,6 @@ Databases contain three `required` fields and two `optional` fields. ConnectionPool is used to configure pgbouncer connection pool. All the fields here are accompanied by default values and can be left unspecified if no customization is required by the user. - `spec.connectionPool.port`: specifies the port on which pgbouncer should listen to connect with clients. The default is 5432. -- `spec.connectionPool.adminUsers`: specifies the values of admin_users. An array of names of admin users are listed here. - `spec.connectionPool.authType`: specifies how to authenticate users. - `spec.connectionPool.poolMode`: specifies the value of pool_mode. - `spec.connectionPool.maxClientConnections`: specifies the value of max_client_conn. @@ -254,8 +256,8 @@ Forwarding from [::1]:5432 -> 5432 Now, let's connect to `postgres` database via PgBouncer using psql. ``` bash -$ env PGPASSWORD=ZFopeLnwkSf_f5Ys psql --host=localhost --port=5432 --username=postgres postgres -psql (14.1 (Ubuntu 14.1-2.pgdg20.04+1), server 13.2) +$ env PGPASSWORD='RoX*L8I;8R7v32ti' psql --host=localhost --port=5432 --username=postgres postgres +psql (14.9 (Ubuntu 14.9-0ubuntu0.22.04.1), server 13.2) Type "help" for help. postgres=# \q @@ -264,7 +266,7 @@ postgres=# \q If everything goes well, we'll be connected to the `postgres` database and be able to execute commands. Let's confirm if the company data we inserted in the `postgres` database before are available via PgBouncer: ```bash -$ env PGPASSWORD=ZFopeLnwkSf_f5Ys psql --host=localhost --port=5432 --username=postgres postgres --command='SELECT * FROM company ORDER BY name;' +$ env PGPASSWORD='RoX*L8I;8R7v32ti' psql --host=localhost --port=5432 --username=postgres postgres --command='SELECT * FROM company ORDER BY name;' name | employee --------+---------- Apple | 10 @@ -272,91 +274,6 @@ $ env PGPASSWORD=ZFopeLnwkSf_f5Ys psql --host=localhost --port=5432 --username=p (2 rows) ``` -## Add New Connections to the Pool - -We will add a new user and a new database to our PostgreSQL server `quick-postgres` and add this database to the existing pool and connect to this database using newly created user. - -First lets create a new user `myuser` with password `mypass` - -```bash -$ env PGPASSWORD=ZFopeLnwkSf_f5Ys psql --host=localhost --port=5432 --username=postgres postgres --command="create user myuser with encrypted password 'mypass'" -CREATE ROLE -``` - -And then create a new database `mydb` - -```bash -$ env PGPASSWORD=ZFopeLnwkSf_f5Ys psql --host=localhost --port=5432 --username=postgres postgres --command="CREATE DATABASE mydb;" -CREATE DATABASE -``` - -And then grant privileges on database `mydb` to `myuser` - -```bash -$ env PGPASSWORD=ZFopeLnwkSf_f5Ys psql --host=localhost --port=5432 --username=postgres postgres --command="grant all privileges on database mydb to myuser" -GRANT -``` - - -Now we will need to edit our PgBouncer's spec.databases to add this database to the connection pool. - -The YAML file should now look like this: - -```yaml -apiVersion: kubedb.com/v1alpha2 -kind: PgBouncer -metadata: - name: pgbouncer-server - namespace: demo -spec: - version: "1.17.0" - replicas: 1 - databases: - - alias: "postgres" - databaseName: "postgres" - databaseRef: - name: "quick-postgres" - namespace: demo - - alias: "tmpdb" - databaseName: "mydb" - databaseRef: - name: "quick-postgres" - namespace: demo - connectionPool: - maxClientConnections: 20 - reservePoolSize: 5 - terminationPolicy: Delete -``` - -We have given our newly added database an alias `tmpdb`. We will now apply this modified file. - -```bash -$ kubectl apply -f https://github.com/kubedb/docs/raw/{{< param "info.version" >}}/docs/examples/pgbouncer/quickstart/pgbouncer-server-mod.yaml -pgbouncer.kubedb.com/pgbouncer-server configured -``` - -Let's try to connect to `mydb` via PgBouncer. - -```bash -$ env PGPASSWORD=mypass psql --host=localhost --port=5432 --username=myuser tmpdb -psql (14.1 (Ubuntu 14.1-2.pgdg20.04+1), server 13.2) -Type "help" for help. - -tmpdb=> -``` - -We can now switch our connection between our existing databases `postgres` and `mydb` as well. - -```bash -tmpdb=> \c postgres -psql (14.1 (Ubuntu 14.1-2.pgdg20.04+1), server 13.2) -You are now connected to database "postgres" as user "myuser". -postgres=> \c tmpdb -psql (14.1 (Ubuntu 14.1-2.pgdg20.04+1), server 13.2) -You are now connected to database "tmpdb" as user "myuser". -tmpdb=> \q -``` - KubeDB operator watches for PgBouncer objects using Kubernetes api. When a PgBouncer object is created, KubeDB operator will create a new StatefulSet and a Service with the matching name. KubeDB operator will also create a governing service for StatefulSet with the name `kubedb`, if one is not already present. KubeDB operator sets the `status.phase` to `Running` once the connection-pooling mechanism is ready. @@ -364,7 +281,7 @@ KubeDB operator sets the `status.phase` to `Running` once the connection-pooling ```bash $ kubectl get pb -n demo pgbouncer-server -o wide NAME VERSION STATUS AGE -pgbouncer-server 1.17.0 Ready 2h +pgbouncer-server 1.18.0 Ready 2h ``` Let's describe PgBouncer object `pgbouncer-server` @@ -378,7 +295,7 @@ Annotations: