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为从库)

相关推荐
苏渡苇31 分钟前
Redis 持久化——RDB 快照 vs AOF 日志
数据库·redis·缓存·redis持久化·aof vs rdb
feng145633 分钟前
OpenSREClaw - AI 本体论思维
运维·人工智能
l1t1 小时前
DeepSeek总结的使用 PEG 实现运行时可扩展的 SQL 解析器
数据库·sql
这个DBA有点耶1 小时前
COUNT进阶(续):超大表去重计数的极致优化
数据库·架构·代码规范
爱喝水的鱼丶1 小时前
SAP-ABAP:SAP 简单报表输出开发系列(共6篇) 第四篇:SAP 报表异常处理机制:数据校验与消息提示规范落地
开发语言·数据库·学习·算法·sap·abap
用户2367829801681 小时前
Linux systemctl 服务管理命令:从 systemd 架构到实战技巧
linux
_1_71 小时前
SQL SERVER闪退问题解决
数据库·sqlserver
ZengLiangYi1 小时前
sql.js WASM 深度解析
javascript·数据库·后端
LIZHUOLONG11 小时前
linux 设备初始化
linux·运维·服务器
遇印记1 小时前
软考知识点(局域网基础)
运维·服务器·局域网