当前位置: 首页 > news >正文

postgresql主从搭建

postgresql主从搭建

主从服务器分别安装好postgresql

主库

创建数据库热备帐号replica,密码123456为例,则执行以下命令

create role replica login replication encrypted password '123456';

打开 pg_hba.conf 配置文件,设置 replica 用户白名单

数据库账号为 replica,从节点的 VPC IPv4 网段为 xx.xx.xx.xx/16,则在 IPv4 local connections 段添加如下内容:

host    all             all           xx.xx.xx.xx/16         md5
允许从服务器连接到主服务器
host    replication     replica         xx.xx.xx.xx/16         md5  
允许从服务器使用replica用户复制vim /var/lib/pgsql/15/data/postgresql.conf找到以下参数,并将参数修改为以下内容:listen_addresses = '*' # 设置监听的ip,* 为允许所有
wal_level = replica # wal日志写入级别,要使用流复制,必须使用replica或更高级别
full_page_writes = on # 可以防止意外宕机后部分数据无法写入
wal_log_hints = on # 没太懂这个参数的具体含义,但可能会影响后续pg_rewind的使用,所以把它打开,官方描述:also do full page writes of non-critical updates
max_wal_senders = 10 # 设置流复制链接最大值
hot_standby = on # 打开热备
wal_keep_segments = 64 # 设置流复制保留的最log数目重启服务systemctl restart postgresql-15.service

从库

清空从库目录

rm -rf /var/lib/pgsql/15/data/*

使用 pg_basebackup 基础备份工具制定备份目录

pg_basebackup -D /var/lib/pgsql/15/data -h 192.168.5.132(主节点公网IP) -p 5432 -U replica(用户) -X stream –P

修改从服务器配置文件

vim /var/lib/pgsql/15/data/postgresql.conf#从机信息和连接用户
primary_conninfo = 'host=192.168.5.132 user=replica password=123456'
#说明恢复到最新状态
recovery_target_timeline = latest 
#大于主节点,正式环境重新考虑此值的大小
max_connections = 120
#说明这台机器不仅可以用户数据归档,还可以用于数据查询
hot_standby = on
#流备份的最大延迟时间
max_standby_archive_delay = 30s
#向主机汇报本地状态的间隔时间
wal_receiver_status_interval = 10s
#出现错误复制,向主机反馈
hot_standby_feedback = on在data下创建一个standby.signal文件vim standby.signal
standby_mode = 'on'修改目录的属组和属主
chown -R postgres.postgres /var/lib/pgsql/15/data重启服务
systemctl restart postgresql-15.service

主库操作

su postgres
psql
进入数据库
select * from pg_stat_replication;
看到从库信息,则主从搭建完毕
http://www.lryc.cn/news/98650.html

相关文章:

  • 将Parasoft和ChatGPT相结合会如何?
  • Go text/template详解:使用指南与最佳实践
  • Stable Diffusion在各种显卡上的加速方式测试,最高可以提速211.2%
  • Java读取外链图片忽略ssl验证转为base64
  • 系统架构设计师 10:软件架构的演化和维护
  • Windows 11 绕过 TPM 方法总结,通用免 TPM 镜像下载 (2023 年 7 月更新)
  • EXCEL,如何比较2个表里的数据差异(使用数据透视表)
  • 字节抖音小程序,使用 uniapp 调起内置支付
  • django模板继承和组件了解
  • 首屏优化,给以图片为背景的元素增加相似背景,优化用户体验,background-image 绘制规则
  • 【用户体验分析报告】 按需加载组件,导致组件渲染卡顿,影响交互体验?组件拆包预加载方案来了!
  • idea 关闭页面右侧预览框/预览条
  • CSS3 Flexbox
  • 东南大学轴承故障诊断(Python代码,CNN模型,适合复合故障诊断研究)
  • ubuntu--Motrix
  • PHP 3des加解密新旧方法可对接加密
  • 【朴素贝叶斯-新闻主题分类】
  • 安卓面试问题记录
  • php-golang-jsonrpc2.0 rpc-codec/jsonrpc2和tivoka/tivoka实践
  • 听力词汇笔记(6级)
  • 【JVM】详细解析java创建对象的具体流程
  • kafka怎么用代码读取数据
  • 网关与路由器的区别
  • 助力工业物联网,工业大数据之工单事实指标需求分析【二十】
  • python_PyQt5开发工具结构基础
  • 【C++】入门基础2
  • Reinforcement Learning with Code 【Chapter 8. Value Funtion Approximation】
  • 常用InnoDB参数介绍
  • 云原生网关部署新范式丨 Higress 发布 1.1 版本,支持脱离 K8s 部署
  • 【通讯录】--C语言