PostgreSQL Streaming Replication 主从

1、在 node1 初始化 PostgreSQL(主库)

bash 复制代码
postgresql-setup --initdb

编辑 /var/lib/pgsql/data/postgresql.conf(关键参数):

bash 复制代码
listen_addresses = '*'
wal_level = replica
max_wal_senders = 10
max_replication_slots = 10
archive_mode = on
archive_command = 'cd .'
hot_standby = on

编辑 /var/lib/pgsql/data/pg_hba.conf,允许 node2 访问和复制:

bash 复制代码
# 允许从库复制
host    replication     repl        10.99.50.32/32       md5

# 允许业务库访问
host    all             all         10.99.50.32/32       md5
host    all             all         10.99.50.31/32       md5

启动主库:

bash 复制代码
systemctl enable --now postgresql

创建复制用户和业务库用户:

bash 复制代码
sudo -u postgres psql <<EOF
CREATE ROLE repl WITH REPLICATION LOGIN PASSWORD 'ReplPass123!';
CREATE DATABASE kea;
CREATE USER kea WITH PASSWORD 'KeaPass123!';
GRANT ALL PRIVILEGES ON DATABASE kea TO kea;

CREATE DATABASE stork;
CREATE USER stork WITH PASSWORD 'StorkPass123!';
GRANT ALL PRIVILEGES ON DATABASE stork TO stork;
EOF

配置postgres用户本地登录认证:

修改postgres密码

bash 复制代码
sudo -u postgres psql
ALTER USER postgres WITH PASSWORD 'PgPass123!';

修改/var/lib/pgsql/data/pg_hba.conf

bash 复制代码
local   all   all   md5

重新加载数据库

bash 复制代码
 systemctl reload postgresql

2、在 node2 配置从库

先停掉 node2 的 PostgreSQL 并清空数据目录:

bash 复制代码
systemctl stop postgresql
rm -rf /var/lib/pgsql/data/*

从主库做 base backup:

bash 复制代码
sudo -u postgres PGPASSWORD='ReplPass123!' pg_basebackup   -h 10.99.50.31 -D /var/lib/pgsql/data -U repl -P -R

启动从库:

bash 复制代码
systemctl enable --now postgresql

3、在主库上确认复制状态

bash 复制代码
sudo -u postgres psql -c "SELECT client_addr, state, sync_state FROM pg_stat_replication;"
相关推荐
承渊政道1 分钟前
【MySQL数据库学习】(MySQL复合查询)
数据库·学习·mysql·bash·database·数据库开发·数据库架构
Cx330❀5 分钟前
【MySQL基础】详解MySQL数据类型:底层原理、越界测试与最佳实践
linux·开发语言·数据库·c++·mysql
Upsy-Daisy11 分钟前
Hermes Agent 学习笔记 07:Messaging Gateway,让 Agent 从终端走向多平台入口
运维·服务器·数据库
程序员晨曦13 分钟前
数据库写轮眼:看透 MVCC 版本链、快照、隔离级别。
数据库·oracle
Leon-Ning Liu17 分钟前
MySQL数据恢复实践:binlog2sql数据追加
数据库·mysql
嵌入式-老费20 分钟前
esp32开发与应用(看门狗测试)
java·开发语言·数据库
czhc114007566320 分钟前
615:代码细节
数据库
知识分享小能手25 分钟前
Hadoop学习教程,从入门到精通, HBase 分布式数据库 — 完整知识点与案例代码(8)
数据库·hadoop·分布式
西凉的悲伤27 分钟前
MySQL WITH RECURSIVE 详解
数据库·mysql·recursive·递归查询·with recursive
吴声子夜歌30 分钟前
SQL经典实例——处理数字
java·数据库·sql