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;"
相关推荐
廿一夏6 小时前
MySql存储引擎与索引
数据库·sql·mysql
曲幽6 小时前
我用了FastApiAdmin后,连夜把踩过的坑都整理出来了
redis·python·postgresql·vue3·fastapi·web·sqlalchemy·admin·fastapiadmin
lzhdim8 小时前
SQL 入门 15:SQL 事务:从 ACID 到四种常见的并发问题
数据库·sql
瀚高PG实验室8 小时前
瀚高企业版V9.1.1在pg_restore还原备份文件时提示extract函数语法问题
数据库·瀚高数据库
TDengine (老段)8 小时前
TDengine Tag 设计哲学与 Schema 变更机制
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
YOU OU9 小时前
Spring IoC&DI
java·数据库·spring
Muscleheng10 小时前
Navicat连接postgresql时出现‘datlastsysoid does not exist‘报错
数据库·postgresql
罗超驿11 小时前
18.事务的隔离性和隔离级别:MySQL面试高频考点全解析
数据库·mysql·面试
jran-11 小时前
Redis 命令
数据库·redis·缓存
小江的记录本12 小时前
【Java基础】Java 8-21新特性:JDK21 LTS:虚拟线程、模式匹配switch、结构化并发、序列集合(附《思维导图》+《面试高频考点清单》)
java·数据库·python·mysql·spring·面试·maven