postgresql12配置主从

一、 1、:安装postgresql-12数据库;(J:\问题解决\mydepot)

初始化数据库才可以启动(/usr/pgsql-12/bin/postgresql-12-setup initdb)

2、:创建具有流复制权限用户:

CREATE ROLE replica login replication encrypted password 'replica的密码';

create role 用户 login replication encrypted password '用户密码';

3、:编辑postgresql.conf(/var/lib/pgsql/12/data)

listen_addresses = '*' #监听所有ip

archive_mode = on #开启归档

archive_command = 'test ! -f /var/lib/pgsql/12/data/pg_archive/%f && cp %p /var/lib/pgsql/12/data//pg_archive/%f' #归档命令

test ! -f /var/lib/pgsql/11/data/pg_archive/%f && cp %p /home/pg/data/pg_archive/%f

wal_level = replica #9.6开始没有hot_standby(热备模式)

max_wal_senders = 2 #最多有2个流复制连接

wal_keep_segments = 16

wal_sender_timeout=60s #流复制超时时间

max_connections = 100 #最大连接数,据说从机需要大于或等于该值

编辑(pg_hba.conf)

**最后添加:host replication replica(创建的用户) 从库ip/子网 trust

host all all 192.168.130.0/24 md5

重启postgresql:systemctl restart postgresql-12

4、:从库配置:

(1、)验证在从库是否可以访问主节点:psql -h 192.168.130.128 -U postgres

(2、)停止从服务器postgresql:systemctl stop postgresql-12

(3、)清除从库数据存储文件夹(建议移到别的目录) rm -rf /var/lib/pgsql/12/data/*

(4、)从主服务器上copy数据到从服务器,这一步叫做'基础备份'

pg_basebackup -h 主节点ip -p 5432 -U replication -Fp -Xs -v -R -D /var/lib/pgsql/12/data

(5、)此时data目录下会出现standby.signal文件,编辑此文件:

添加:standby_mode= 'on'

(6、)修改postgresql.conf文件(/var/lib/pgsql/12/data)

primary_conninfo = 'host=主节点IP port=5432 user=replica password=replica用户的密码' #从机信息和连接用户

recovery_target_timeline = latest #说明回复到最新状态

max_connections = 120 #大于主节点,正式环境应当重新考虑此值的大小

hot_standby = on #说明这台机器不仅用于数据归档,还可以用于数据查询

max_standby_streaming_delay = 30s #流备份的最大延迟时间

wal_receiver_status_interval = 10s #向主机汇报本机状态的间隔时间

hot_standby_feedback = on #r出现错误复制,向主机反馈

(7、)重启从库:systemctl restart postgresql-12

5、连接主库执行:select client_addr,sync_state from pg_stat_replication; (有数据代表成功)

6、select pg_is_in_recovery();(结果显示f为主库,t为从库)

相关推荐
XDHCOM几秒前
ORA-00054资源忙故障修复,远程处理Oracle报错解决方案,数据库锁超时NOWAIT指定问题排查
数据库·oracle
22信通小白3 分钟前
USRP初学者使用手册(基础配置及bug记录)——Linux+Clion(单台X310收发)
linux·运维·c++·5g·bug·信息与通信
网络安全许木4 分钟前
自学渗透测试第14天(信息收集进阶与指纹识别)
linux·网络安全·渗透测试
q210306337211 分钟前
初学Access(具体示例)
数据库
xlq2232215 分钟前
40.线程控制
linux
l1t1 小时前
DeepSeek总结的PostgreSQL使用 RDTSC 降低 EXPLAIN ANALYZE 的计时开销
数据库·postgresql
lagrahhn1 小时前
Oracle中各个c版本介绍
数据库·oracle
知识分享小能手1 小时前
MongoDB入门学习教程,从入门到精通,在生产环境中设置MongoDB(21)
数据库·学习·mongodb
TechMasterPlus1 小时前
Linux U-Boot 与内核启动流程深度解析:从上电到 Shell 的完整之旅
linux·运维·服务器
XDHCOM1 小时前
ORA-12445报错:无法更改列隐藏属性,Oracle故障修复与远程处理,网友推荐解决方案
数据库·oracle