PG主从搭建【转】
前言
❝PostgreSQL在9.x之后引入了主从的流复制机制,流复制同步方式有同步、异步两种
1.主从流复制介绍
在流复制中,三种类型的进程协同工作:
1.主服务器上的walsender进程将WAL(预写日志)数据发送到备用服务器。
2.备用服务器上的walreceiver进程接收并重放WAL数据。
3.备用服务器上的启动进程启动walreceiver进程。
walsender和walreceiver使用单个TCP连接进行通信。
2.主库白名单设置
su - postgres
cat > $PGDATA/pg_hba.conf << EOF
# TYPE DATABASE USER ADDRESS METHOD
local all all trust
host all all 127.0.0.1/32 trust
host all all 0.0.0.0/0 md5
host replication all 0.0.0.0/0 md5
local replication all trust
EOF
3.主库开归档
[root@primary ~]# mkdir -p /var/lib/pgsql/archive
[root@primary ~]# chown -R postgres.postgres /var/lib/pgsql/archive
su - postgres
cat >> $PGDATA/postgresql.conf <<"EOF"
wal_level='replica'
archive_mode='on'
archive_command='test ! -f /var/lib/pgsql/archive/%f && cp %p /var/lib/pgsql/archive/%f'
restore_command='cp /var/lib/pgsql/archive/%f %p'
max_wal_senders=10
EOF
4.主库创建复制用户
create role repladm login encrypted
password 'replica' replication;
5.从库对主库备份
mkdir -p /backup
chown postgres:postgres /backup
su - postgres
pg_basebackup -h 192.168.6.20 -p 5432 -U repladm -l bk20240411 -F p -P -R -D /backup
执行完成后,从库会产生文件standby.signal,如下:
6.还原从库
关闭从库,删除从库的数据文件,并且将备份文件覆盖从库的数据文件
[postgres@standby01 ~]$echo $PGDATA
/pgccc/pgdata
[postgres@standby01 ~]$ rm -rf /pgccc/pgdata/*
[postgres@standby01 ~]$ cp -r /backup/* /pgccc/pgdata/*
修改从库primary_conninfo参数
cat >> $PGDATA/postgresql.conf <<"EOF"
primary_conninfo = 'host=192.168.6.20 port=5432 user=repladm password=replica'
EOF
重启备库
[postgres@standby01 ~]$ pg_ctl start
7.主从状态
--主库查看wal日志发送状态
select * from pg_stat_replication;
--从库查看wal日志接收状态
select * from pg_stat_wal_receiver;
8.主从复制同步测试
8.1 主库插入
postgres=# create table test(id int,info text);
postgres=# insert into test select n,'test'
from generate_series(1,2000) as n;
8.2 从库验证
9.总结
❝本文详细介绍了物理复制(流复制)的搭建,可以从实例级复制出一个与主库一模一样的实例级的从库
转自
挺好看的一位实习生,PG主流从搭建的如此666
https://mp.weixin.qq.com/s?__biz=MzI3OTE0NDIyNw==&mid=2247493015&idx=1&sn=926a9948af0690936b5f6cb0a9d2eb20&chksm=eaf984ffb0ce66de6f2017a8f0bdd8c9ed790ca6f849f357f8743c2bd02c253488e99fbce642&scene=132&exptype=timeline_recommend_article_extendread_samebiz&show_related_article=1&subscene=0&scene=132#wechat_redirect
踩了一堆坑,终于掌握了PG主从流的精髓
https://mp.weixin.qq.com/s/ji-umytSocYDcx2CMYBOEg