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

相关推荐
ClouGence3 小时前
SQL Server CDC 能放到 Always On 备库读吗?一文讲透原理与实践
数据库·sql server
orion5716 小时前
Missing Semester Class1:course overview and introduction of shell
linux
先吃饱再说20 小时前
存储的进化:从 MySQL 到浏览器缓存,数据到底住在哪?
数据库
Nturmoils20 小时前
字段太多看不全,ksql 的展开模式和输出控制怎么用
数据库·后端
SkyWalking中文站21 小时前
认识 Horizon UI · 6/17:Trace 探索器
运维·监控·自动化运维
用户120487221611 天前
Linux驱动编译与加载
linux·嵌入式
Databend1 天前
Agent 轨迹分析与归因的数据工程实践
大数据·数据库·agent
这个DBA有点耶1 天前
SQL改写进阶:标量子查询的“隐形代价”与消除实战
数据库·mysql·架构
火车叼位1 天前
写给初级开发者:SSL、SSH、HTTPS 与证书体系全解析
运维
smallyoung1 天前
数据库乐观锁深度解析:MySQL、PostgreSQL 实战 + Spring Boot 集成指南
数据库·mysql·postgresql