Registramos el primer nodo en el cluster:
[postgres@postgres1 ~]$ repmgr primary register
INFO: connecting to primary database...
NOTICE: attempting to install extension "repmgr"
NOTICE: "repmgr" extension successfully installed
NOTICE: primary node record (ID: 1) registered
Mostramos el estado del cluster:
[postgres@postgres1 ~]$ repmgr cluster show
ID | Name | Role | Status | Upstream | Location | Priority | Timeline | Connection string
----+-----------+---------+-----------+----------+----------+----------+----------+----------------------------------------------
1 | postgres1 | primary | * running | | default | 100 | 1 | host=192.168.0.101 user=repmgr dbname=repmgr
[postgres@postgres1 ~]$ psql -U repmgr -d repmgr -h 192.168.0.101 -c "SELECT * FROM repmgr.nodes"
node_id | upstream_node_id | active | node_name | type | location | priority | conninfo | repluser | slot_name | config_file
---------+------------------+--------+-----------+---------+----------+----------+----------------------------------------------+----------+---------------+----------------------------
1 | | t | postgres1 | primary | default | 100 | host=192.168.0.101 user=repmgr dbname=repmgr | repmgr | repmgr_slot_1 | /etc/repmgr/13/repmgr.conf
(1 row)
[postgres@postgres1 ~]$ repmgr node status
Node "postgres1":
PostgreSQL version: 13.1
Total data size: 31 MB
Conninfo: host=192.168.0.101 user=repmgr dbname=repmgr
Role: primary
WAL archiving: enabled
Archive command: /bin/true
WALs pending archiving: 0 pending files
Replication connections: 0 (of maximal 10)
Replication slots: 0 physical (of maximal 10; 0 missing)
Replication lag: n/a
[postgres@postgres1 ~]$ repmgr node check
Node "postgres1":
Server role: OK (node is primary)
Replication lag: OK (N/A - node is primary)
WAL archiving: OK (0 pending archive ready files)
Upstream connection: OK (N/A - node is primary)
Downstream servers: OK (this node has no downstream nodes)
Replication slots: OK (node has no physical replication slots)
Missing physical replication slots: OK (node has no missing physical replication slots)
Configured data directory: OK (configured "data_directory" is "/var/lib/pgsql/13/data")
Ahora clonamos la base de datos primary (postgres1) a la secondary (postgres2):
[postgres@postgres2 ~]$ repmgr -h 192.168.0.101 -U repmgr -d repmgr standby clone --fast-checkpoint
NOTICE: destination directory "/var/lib/pgsql/13/data" provided
INFO: connecting to source node
DETAIL: connection string is: host=192.168.0.101 user=repmgr dbname=repmgr
DETAIL: current installation size is 31 MB
NOTICE: checking for available walsenders on the source node (2 required)
NOTICE: checking replication connections can be made to the source server (2 required)
INFO: checking and correcting permissions on existing directory "/var/lib/pgsql/13/data"
INFO: creating replication slot as user "repmgr"
NOTICE: starting backup (using pg_basebackup)...
INFO: executing:
/usr/pgsql-13/bin/pg_basebackup -l "repmgr base backup" -D /var/lib/pgsql/13/data -h 192.168.0.101 -p 5432 -U repmgr -c fast -X stream -S repmgr_slot_2
NOTICE: standby clone (using pg_basebackup) complete
NOTICE: you can now start your PostgreSQL server
HINT: for example: sudo /bin/systemctl start postgresql-13
HINT: after starting the server, you need to register this standby with "repmgr standby register"
Arrancamos la instancia:
[postgres@postgres2 ~]$ sudo systemctl start postgresql-13
Registramos la secondary en el cluster:
[postgres@postgres2 ~]$ repmgr standby register
INFO: connecting to local node "postgres2" (ID: 2)
INFO: connecting to primary database
WARNING: --upstream-node-id not supplied, assuming upstream node is primary (node ID 1)
INFO: standby registration complete
NOTICE: standby node "postgres2" (ID: 2) successfully registered
Configuración del cluster actual:
[postgres@postgres2 ~]$ repmgr cluster show
ID | Name | Role | Status | Upstream | Location | Priority | Timeline | Connection string
----+-----------+---------+-----------+-----------+----------+----------+----------+----------------------------------------------
1 | postgres1 | primary | * running | | default | 100 | 1 | host=192.168.0.101 user=repmgr dbname=repmgr
2 | postgres2 | standby | running | postgres1 | default | 100 | 1 | host=192.168.0.102 user=repmgr dbname=repmgr
Clonamos la segunda secondary (postgres3):
[postgres@postgres3 ~]$ repmgr -h 192.168.0.101 -U repmgr -d repmgr standby clone --fast-checkpoint
NOTICE: destination directory "/var/lib/pgsql/13/data" provided
INFO: connecting to source node
DETAIL: connection string is: host=192.168.0.101 user=repmgr dbname=repmgr
DETAIL: current installation size is 31 MB
NOTICE: checking for available walsenders on the source node (2 required)
NOTICE: checking replication connections can be made to the source server (2 required)
INFO: checking and correcting permissions on existing directory "/var/lib/pgsql/13/data"
INFO: creating replication slot as user "repmgr"
NOTICE: starting backup (using pg_basebackup)...
INFO: executing:
/usr/pgsql-13/bin/pg_basebackup -l "repmgr base backup" -D /var/lib/pgsql/13/data -h 192.168.0.101 -p 5432 -U repmgr -c fast -X stream -S repmgr_slot_3
NOTICE: standby clone (using pg_basebackup) complete
NOTICE: you can now start your PostgreSQL server
HINT: for example: sudo /bin/systemctl start postgresql-13
HINT: after starting the server, you need to register this standby with "repmgr standby register"
Arrancamos la instancia:
[postgres@postgres3 ~]$ sudo systemctl start postgresql-13
Registramos la secondary (postgres3) contra la primary (postgres1) se podría hacer sobre postgres2:
[postgres@postgres3 ~]$ repmgr standby register
INFO: connecting to local node "postgres3" (ID: 3)
INFO: connecting to primary database
WARNING: --upstream-node-id not supplied, assuming upstream node is primary (node ID 1)
INFO: standby registration complete
NOTICE: standby node "postgres3" (ID: 3) successfully registered
Y mostramos el estado del cluster:
[postgres@postgres3 ~]$ repmgr cluster show
ID | Name | Role | Status | Upstream | Location | Priority | Timeline | Connection string
----+-----------+---------+-----------+-----------+----------+----------+----------+----------------------------------------------
1 | postgres1 | primary | * running | | default | 100 | 1 | host=192.168.0.101 user=repmgr dbname=repmgr
2 | postgres2 | standby | running | postgres1 | default | 100 | 1 | host=192.168.0.102 user=repmgr dbname=repmgr
3 | postgres3 | standby | running | postgres1 | default | 100 | 1 | host=192.168.0.103 user=repmgr dbname=repmgr
[postgres@postgres1 ~]$ repmgr cluster matrix
INFO: connecting to database
Name | ID | 1 | 2 | 3
-----------+----+---+---+---
postgres1 | 1 | * | * | *
postgres2 | 2 | * | * | *
postgres3 | 3 | * | * | *
[postgres@postgres1 ~]$ repmgr cluster crosscheck
INFO: connecting to database
Name | ID | 1 | 2 | 3
-----------+----+---+---+---
postgres1 | 1 | * | * | *
postgres2 | 2 | * | * | *
postgres3 | 3 | * | * | *
Ver switchover y failover