Charmed PostgreSQL Tutorial | 2. Deploy PostgreSQL

Charmed PostgreSQL VM Tutorial > 2. Deploy PostgreSQL

Deploy Charmed PostgreSQL VM

In this section, you will deploy Charmed PostgreSQL VM, access a unit, and interact with the PostgreSQL databases that exist inside the application.

Summary


Deploy PostgreSQL

To deploy Charmed PostgreSQL, all you need to do is run

juju deploy postgresql

Juju will now fetch Charmed PostgreSQL VM from Charmhub and deploy it to the LXD cloud. This process can take several minutes depending on how provisioned (RAM, CPU, etc) your machine is.

You can track the progress by running:

juju status --watch 1s

This command is useful for checking the real-time information about the state of a charm and the machines hosting it. Check the juju status documentation for more information about its usage.

When the application is ready, juju status will show something similar to the sample output below:

Model     Controller  Cloud/Region         Version  SLA          Timestamp
tutorial  overlord    localhost/localhost  3.1.7    unsupported  09:41:53+01:00

App         Version  Status  Scale  Charm       Channel    Rev  Exposed  Message
postgresql           active      1  postgresql  14/stable  281  no       

Unit           Workload  Agent  Machine  Public address  Ports  Message
postgresql/0*  active    idle   0        10.89.49.129           

Machine  State    Address       Inst id        Series  AZ  Message
0        started  10.89.49.129  juju-a8a31d-0  jammy       Running

You can also watch juju logs with the juju debug-log command. More info on logging in the juju logs documentation.

Access PostgreSQL

Warning: This part of the tutorial accesses PostgreSQL via the operator user.

Do not directly interface with the operator user in a production environment.

In a later section about Integrations, we will cover how to safely access PostgreSQL by creating a separate user via the Data Integrator charm

Retrieve credentials

Connecting to the database requires that you know the values for host, username and password.

To retrieve these values, run the Charmed PostgreSQL action get-password:

juju run postgresql/leader get-password

Running the command above should output:

unit-postgresql-0:
  UnitId: postgresql/0
  id: "2"
  results:
    operator-password: <password>
  status: completed
  timing:
    completed: 2023-03-20 08:42:22 +0000 UTC
    enqueued: 2023-03-20 08:42:19 +0000 UTC
    started: 2023-03-20 08:42:21 +0000 UTC

To request a password for a different user, use the option username:

juju run postgresql/leader get-password username=replication

The IP address of the unit hosting the PostgreSQL application, also referred to as the “host”, can be found with juju status:

...
Unit           Workload  Agent  Machine  Public address  Ports  Message
postgresql/0*  active    idle   0        10.89.49.129       
...

Access PostgreSQL via psql

To access the units hosting Charmed PostgreSQL, run

juju ssh postgresql/leader

If at any point you’d like to leave the unit hosting Charmed PostgreSQL K8s, enter Ctrl+D or type exit.

The easiest way to access PostgreSQL is via the PostgreSQL interactive terminal psql, which is already installed here.

To list all available databases, run:

psql --host=10.89.49.129 --username=operator --password --list

When requested, enter the <password> for charm user operator that you obtained earlier.

Example output:

                              List of databases
   Name    |  Owner   | Encoding | Collate |  Ctype  |   Access privileges   
-----------+----------+----------+---------+---------+-----------------------
 postgres  | operator | UTF8     | C.UTF-8 | C.UTF-8 | 
 template0 | operator | UTF8     | C.UTF-8 | C.UTF-8 | =c/operator          +
           |          |          |         |         | operator=CTc/operator
 template1 | operator | UTF8     | C.UTF-8 | C.UTF-8 | =c/operator          +
           |          |          |         |         | operator=CTc/operator
(3 rows)

You can now interact with PostgreSQL directly using PostgreSQL SQL Queries. For example, entering SELECT version(); should output something like:

> psql --host=10.89.49.129 --username=operator --password postgres
Password: 
psql (14.7 (Ubuntu 14.7-0ubuntu0.22.04.1))
Type "help" for help.

postgres=# SELECT version();
                                                               version                                                                
--------------------------------------------------------------------------------------------------------------------------------------
 PostgreSQL 14.7 (Ubuntu 14.7-0ubuntu0.22.04.1) on x86_64-pc-linux-gnu, compiled by gcc (Ubuntu 11.3.0-1ubuntu1~22.04) 11.3.0, 64-bit
(1 row)

Feel free to test out any other PostgreSQL queries.

When you’re ready to leave the PostgreSQL shell, you can just type exit. This will take you back to the host of Charmed PostgreSQL K8s (postgresql-k8s/0). Exit this host by once again typing exit. Now you will be in your original shell where you first started the tutorial. Here you can interact with Juju and LXD.

Next step: 3. Scale replicas

I just tried deploying from the 14/stable channel and the instance doesn’t seem to have that installed, but does have charmed-postgresql.psql installed per this pastebin.

Dear Tom, thank you for the report! The documentation created before the migration to SNAP, as a result the proper binary now is charmed-postgresql.psql, while I agree it is not very user friendly.

We are going to add SNAP aliases for both postrgresql and mysql charms. Once again, than you for noticing and reporting back!

1 Like

This doesn’t seem to work right now with the 14/stable series charm; I’m having problems with charmed-postgresql.psql not being able to open sockets. I’ve filed a bug: Bug #2031195 “charmed-postgresql.psql not working for login to p...” : Bugs : PostgreSQL Charm

Nevermind - as pointed out by the person who replied on that bug, it does work with the 14/edge charm, plus there is an appropriate alias from psql to charmed-postgresql.psql in that version.

The one other issue I see here is that the “run-action” command is correct for Juju < 3.x, but is now “run” in Juju >= 3.x. As everything seems to be moving away from Juju 2.x, it seems worth calling out.

1 Like