Setting Up PostgreSQL Logical Replication with Docker Compose
Hi everyone ๐,
Sorry๐
for not posting any blogs; I was stuck in other work. In the previous post, we saw that we enabled MySQL Replication using GTID. Today, we see how to allow Postgres Logical Replication in our local setup using docker-compose.
Environment Setup
We have two PostgreSQL instances configured using Docker Compose:
pg_hba.conf
Environment Setup
We have two PostgreSQL instances configured using Docker Compose:
- Publisher (postgres-1): The source server where changes are captured.
- Subscriber (postgres-2): The destination server that receives replicated data.
Docker Compose Configuration
Publisher (docker-compose.yml)
version: '3.8'
services:
postgres-1:
build: ./
container_name: postgres-1
environment:
POSTGRES_USER: postgresadmin
POSTGRES_PASSWORD: admin123
POSTGRES_DB: postgresdb
PGDATA: "/data"
volumes:
- ./postgres-1/pgdata:/data
- ./postgres-1/config:/config
- ./postgres-1/archive:/mnt/server/archive
ports:
- "5000:5432"
networks:
- custom_network
command: -c 'config_file=/config/postgresql.conf'
restart: unless-stopped
networks:
custom_network:
name: postgres
driver: bridge
Subscriber (docker-compose.yml)
version: '3.8'
services:
postgres-2:
build: ./
container_name: postgres-2
environment:
POSTGRES_USER: postgresadmin
POSTGRES_PASSWORD: admin123
POSTGRES_DB: postgresdb
PGDATA: /data
volumes:
- ./postgres-2/pgdata:/data
- ./postgres-2/config:/config
- ./postgres-2/archive:/mnt/server/archive
ports:
- "5001:5432"
networks:
- custom_network
command: -c 'config_file=/config/postgresql.conf'
restart: unless-stopped
networks:
custom_network:
name: postgres
driver: bridge
PostgreSQL Configuration
To enable logical replication, update the postgresql.conf and pg_hba.conf for each server.
postgresql.conf (Publisher and Subscriber)
wal_level = logical
max_wal_senders = 3
shared_preload_libraries = 'pglogical'
Publisher:
host pub replicator 0.0.0.0/0 md5
host all all 0.0.0.0/0 md5
Subscriber:
host all all 0.0.0.0/0 md5
Steps to Configure Logical Replication
- Start Both PostgreSQL Containers
- docker compose -f docker-compose1.yml up -d
- docker compose -f docker-compose2.yml up -d
- Create a Test Database
- CREATE DATABASE chiragLogicalRep;
- Create a Replication Role on Publisher
- CREATE ROLE chirag WITH REPLICATION LOGIN PASSWORD 'admin@123';
- GRANT ALL PRIVILEGES ON DATABASE chiragLogicalRep TO chirag;
- Set Up Publication on Publisher
- \c chiragLogicalRep
- CREATE TABLE products (id SERIAL, name TEXT, price DECIMAL);
- CREATE PUBLICATION my_publication;
- ALTER PUBLICATION my_publication ADD TABLE products;
- Set Up Subscription on Subscriber: Connect to chiragLogicalRep on the subscriber and execute:
- CREATE SUBSCRIPTION my_subscription
- CONNECTION 'host=192.168.0.211 port=5000 user=chirag password=admin@123 dbname=chiragLogicalRep'
- PUBLICATION my_publication;
- Verify Replication: Insert data into the products table on the publisher:
- INSERT INTO products (name, price) VALUES ('Pen', 5.90), ('Notebook', 9.10), ('Pencil', 8.50);
- Query the products table on both servers to ensure data synchronization:
- SELECT * FROM products;
Advanced Configuration
Replica Identity
- To enable updates and deletes, configure the replica identity on the publisher:
- ALTER TABLE products REPLICA IDENTITY FULL;
Replication status
- To check replication status run following command
- SELECT * FROM pg_publication_tables WHERE pubname = 'my_publication';
If both servers show the same data in the products table that means we enabled data synchronization from publisher to subscriber.
This blog post provides a straightforward approach to setting up PostgreSQL logical replication in a Dockerized environment. For further details, visit the Svastikkka/DOCKER repository.
Comments
Post a Comment
Please give us your valuable feedback