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;"
相关推荐
m0_613856292 小时前
mysql如何利用事务隔离级别解决特定业务冲突_mysql隔离方案选型
jvm·数据库·python
Adios7942 小时前
VPR:Pitts50K和Norland数据集下载
数据库
东风破1372 小时前
DM用户权限、表、约束等对象的基本操作,SQL日志的开启介绍
数据库·sql·dm达梦数据库
收获不止数据库3 小时前
达梦9发布会归来:AI 时代,我们需要一款什么样的数据库?
数据库·人工智能·ai·语言模型·数据分析
小宇的天下3 小时前
Virtuoso GUI 界面中的关键模块定义
数据库
bqq198610263 小时前
MySQL 5.7 与 MySQL 8.0 的主要区别
数据库·mysql
Elastic 中国社区官方博客4 小时前
Elastic-caveman : 在不损失 Elastic 最佳效果的情况下,将 AI 响应 tokens 减少64%
大数据·运维·数据库·人工智能·elasticsearch·搜索引擎·全文检索
互联网推荐官4 小时前
上海软件定制开发全流程拆解:需求分析、技术选型与交付管理的工程实践
大数据·数据库·需求分析
专注API从业者4 小时前
Open Claw 京东商品监控选品实战:一键抓取、实时监控、高效选品
java·服务器·数据库
大迪deblog4 小时前
系统架构师-数据库-数据库设计
数据库·oracle·系统架构