From 01b82ef4d1267e9dce45a24ac04e2737f1873b9e Mon Sep 17 00:00:00 2001 From: Marcelo Henrique Neppel Date: Fri, 12 Aug 2022 09:02:01 -0300 Subject: [PATCH] Readme updates (#24) * Add License section * Add Security section * Update Relations section * Update Usage section * Add replicaiton section * Rename operator * Add other legacy relation command * Fix model info retrieval --- README.md | 92 +++++++++++----------- tests/integration/new_relations/helpers.py | 2 +- 2 files changed, 46 insertions(+), 48 deletions(-) diff --git a/README.md b/README.md index aeed659d70..157b1d15e6 100644 --- a/README.md +++ b/README.md @@ -1,81 +1,79 @@ -# PostgreSQL Kubernetes Operator +# Charmed PostgreSQL Kubernetes Operator ## Description -The PostgreSQL Kubernetes Operator deploys and operates the [PostgreSQL](https://www.postgresql.org/about/) database on Kubernetes clusters. +The Charmed PostgreSQL Kubernetes Operator deploys and operates the [PostgreSQL](https://www.postgresql.org/about/) database on Kubernetes clusters. -This operator provides a Postgres database with replication enabled (one master instance and one or more hot standby replicas). The Operator in this repository is a Python script which wraps the LTS Postgres versions distributed by [Ubuntu](https://hub.docker.com/r/ubuntu/postgres) and adding [Patroni](https://github.com/zalando/patroni) on top of it, providing lifecycle management and handling events (install, configure, integrate, remove). +This operator provides a Postgres database with replication enabled (one master instance and one or more hot standby replicas). The Operator in this repository is a Python script which wraps the LTS Postgres versions distributed by [Ubuntu](https://hub.docker.com/r/ubuntu/postgres) and adding [Patroni](https://github.com/zalando/patroni) on top of it, providing lifecycle management and handling events (install, configure, integrate, remove, etc). ## Usage -To deploy this charm using Juju 2.9.0 or later, run: - +### Basic Usage +To deploy a single unit of PostgreSQL using its default configuration. ```shell -juju add-model postgresql -charmcraft pack -juju deploy ./postgresql-k8s_ubuntu-20.04-amd64.charm +juju deploy postgresql-k8s --channel edge --trust ``` -Note: the above model must exist inside a k8s cluster (you can use juju bootstrap to create a controller in the k8s cluster). - -To confirm the deployment, you can run: +Note: `--trust` is required because the charm and Patroni need to create some k8s resources. +It is customary to use PostgreSQL with replication. Hence usually more than one unit (preferably an odd number to prohibit a "split-brain" scenario) is deployed. To deploy PostgreSQL with multiple replicas, specify the number of desired units with the `-n` option. ```shell -juju status --color +juju deploy postgresql-k8s --channel edge -n --trust ``` -Once PostgreSQL starts up, it will be running on the default port (5432). - -If required, you can remove the deployment completely by running: - +To retrieve primary replica one can use the action `get-primary` on any of the units running PostgreSQL. ```shell -juju destroy-model -y postgresql --destroy-storage +juju run-action postgresql-k8s/ get-primary --wait ``` -Note: the `--destroy-storage` will delete any data persisted by PostgreSQL. +Similarly, the primary replica is displayed as a status message in `juju status`, however one should note that this hook gets called on regular time intervals and the primary may be outdated if the status hook has not been called recently. -## Relations - -We have added support for two legacy relations (from the [original version](https://launchpad.net/charm-k8s-postgresql) of the charm): +### Replication +#### Adding Replicas +To add more replicas one can use the `juju scale-application` functionality i.e. +```shell +juju scale-application postgresql-k8s -n +``` +The implementation of `scale-application` allows the operator to add more than one unit, but functions internally by adding one replica at a time, avoiding multiple replicas syncing from the primary at the same time. -1. `db` is a relation that one uses when it is needed only a new database and a user with permissions on it. The following commands can be executed to deploy and relate to the FINOS Waltz Server charm: +#### Removing Replicas +Similarly to scale down the number of replicas the `juju scale-application` functionality may be used i.e. ```shell -# Pack the charm -charmcraft pack +juju scale-application postgresql-k8s -n +``` +The implementation of `scale-application` allows the operator to remove more than one unit. The functionality of `scale-application` functions by removing one replica at a time to avoid downtime. -# Deploy the relevant charms -juju deploy ./postgresql-k8s_ubuntu-20.04-amd64.charm \ - --resource postgresql-image=dataplatformoci/postgres-patroni - -n 3 --trust -juju deploy finos-waltz-k8s +## Relations -# Reduce the update status frequency to speed up nodes being added to the cluster. -juju model-config update-status-hook-interval=10s +Supported [relations](https://juju.is/docs/olm/relations): -# Relate FINOS Waltz Server with PostgreSQL -juju relate finos-waltz-k8s postgresql:shared-db -``` +#### New `postgresql_client` interface: -1. `db-admin` is a relation that one uses when the application needs to connect to the database cluster with superuser privileges. The following commands can be executed to deploy and relate to the Discourse charm: +Relations to new applications are supported via the `postgresql_client` interface. To create a relation: ```shell -# Pack the charm -charmcraft pack - -# Deploy the relevant charms -juju ./postgresql-k8s_ubuntu-20.04-amd64.charm \ - --resource postgresql-image=dataplatformoci/postgres-patroni - -n 3 --trust -juju deploy discourse-k8s +juju relate postgresql-k8s application +``` -# Reduce the update status frequency to speed up nodes being added to the cluster. -juju model-config update-status-hook-interval=10s +To remove a relation: +```shell +juju remove-relation postgresql-k8s application +``` -# Relate Discourse with PostgreSQL -juju relate discourse-k8s postgresql-k8s:db-admin +#### Legacy `pgsql` interface: +We have also added support for the two database legacy relations from the [original version](https://launchpad.net/charm-k8s-postgresql) of the charm via the `pgsql` interface. Please note that these relations will be deprecated. + ```shell +juju relate postgresql-k8s:db finos-waltz-k8s +juju relate postgresql-k8s:db-admin discourse-k8s ``` +## Security +Security issues in the Charmed PostgreSQL Kubernetes Operator can be reported through [LaunchPad](https://wiki.ubuntu.com/DebuggingSecurity#How%20to%20File). Please do not file GitHub issues about security issues. + ## Contributing Please see the [Juju SDK docs](https://juju.is/docs/sdk) for guidelines on enhancements to this charm following best practice guidelines, and [CONTRIBUTING.md](https://github.com/canonical/postgresql-k8s-operator/blob/main/CONTRIBUTING.md) for developer guidance. + +## License +The Charmed PostgreSQL Kubernetes Operator is free software, distributed under the Apache Software License, version 2.0. See [LICENSE](https://github.com/canonical/postgresql-k8s-operator/blob/main/LICENSE) for more information. diff --git a/tests/integration/new_relations/helpers.py b/tests/integration/new_relations/helpers.py index 911fd8047d..3ec9484de9 100644 --- a/tests/integration/new_relations/helpers.py +++ b/tests/integration/new_relations/helpers.py @@ -54,7 +54,7 @@ async def build_connection_string( host = endpoints.split(",")[0].split(":")[0] # Translate the service hostname to an IP address. - model = await ops_test.model.get_info() + model = ops_test.model.info client = AsyncClient(namespace=model.name) service = await client.get(Service, name=host.split(".")[0]) ip = service.spec.clusterIP