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

Postgresql 主从复制+主从切换(流复制)

pgsql有多种主从复制方式,推荐的是流复制

一、前置条件

1.至少两个pgsql数据库(可以是一台设备上的两个)

可以参考下面的教程
pgsql编译安装:pgsql 编译安装(linux)
pgsql单机多开:pgsql 单机多开

2.两个数据库已经用工具连接上

9版本后才支持流复制,完成的支持建议用10以后的版本(现在应该都用是14,15了)

3.流复制优点说明

即使副库和主库连接断开一段时间,也不会影响(时间太长了不行)

二、配置主从

演示主机如下
主库机 192.168.0.233:5432
从库机 192.168.0.165:5432

(一)主库操作

1.创建复制账号

psql
CREATE USER replica replication encrypted password 'replica';

2.修改pg_hba.conf

vi /var/pgsqldata/pg_hba.conf

添加下面内容

host   replication    replica    192.168.0.165/32     trust

如果有host all all这样的字段,记得写在这个之上

3.修改postgresql.conf

vi /var/pgsqldata/postgresql.conf

找到REPLICATION模块配置,默认状态是全部为注释状态,这里有几个参数可以调整,也可以默认不改动:

级别
wal_level = replica

4.重启数据库

systemctl restart pgsql

(二)从库操作

1.先关闭数据库进程

systemctl stop pgsql

2.基础备份

先将当前的已有的数据做基础备份

cd /var/pgsqldata
pg_basebackup -F p -P -R -D /var/pgsqldata -h 192.168.0.233 -p 5432 -U replica -W

密码为上面设定的replica

如果当前目录不为空,是不能操作的,可以删除当前目录的全部内容,然后在运行上面的命令

chmod -R 750 /var/pgsqldata
chown -R postgres:postgres /var/pgsqldata

3.修改postgresql.conf

vi /var/pgsqldata/postgresql.conf

修改下面几个部分
hot_standby = on # 说明这台机器不仅仅是用于数据归档,也用于数据查询

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

wal_receiver_status_interval = 10s # 多久向主报告一次从的状态

hot_standby_feedback = on # 如果有错误的数据复制,是否向主进行反馈

4.启动从服务器

systemctl restart pgsql

(三)检查连接是否同步

在主库的psql,输入下面的命令,可以查看所有的连接,有说明已经正常了

select client_addr,sync_state from pg_stat_replication;

三、其它注意事项和可能遇到问题

(一)时区/地区问题

如果主从的时区不同,会报错。
可以用下面的进行检查处理

1.主库设备

locale

找到第一个显示的地区

2.从库设备

dpkg-reconfigure locales

然后在列表中找到主库的地区,输入数字即可

(二)权限问题

1.pgsql的目录权限是750,其它无法启动

(三)插件问题

1.从库必须有主库的插件,否则会启动失败

http://www.lryc.cn/news/182353.html

相关文章:

  • java获取字符串集合中每个字符并且组成一个新的集合实现
  • 结构型设计模式——外观模式
  • 【算法学习】-【双指针】-【快乐数】
  • 【Java-LangChain:使用 ChatGPT API 搭建系统-6】处理输入-链式 Prompt Chaining Prompts
  • 从零手搓一个【消息队列】创建核心类, 数据库设计与实现
  • 14:00面试,14:06就出来了,这问的过于变态了。。。
  • url请求头信息
  • 【Oracle】Oracle系列之十六--数据库备份
  • uni-app:实现页面效果3
  • 计算机网络基础(一):网络系统概述、OSI七层模型、TCP/IP协议及数据传输
  • 互联网金融理财知识点简单总结
  • 微信小程序template界面模板导入
  • C/C++跨平台构建工具CMake-----在C++源码中读取CMakeLists.txt配置文件中的内容
  • 【MVP争夺战】python实现-附ChatGPT解析
  • 6 个最佳免费 Android 数据恢复软件
  • 数学建模Matlab之数据预处理方法
  • 如何保证Redis的HA高可用
  • 第一百六十三回 如何在任意位置显示PopupMenu
  • 采用python中的opencv2的库来运用机器视觉移动物体
  • 一、thymeleaf简介
  • 二分查找模版
  • idea清空缓存类
  • PAT(Basic Level) Practice(中文) 1015德才论
  • 接口自动化测试的概述及流程梳理~
  • 竞赛 机器视觉 opencv 深度学习 驾驶人脸疲劳检测系统 -python
  • 虚拟货币(也称为加密货币或数字货币)的运作
  • N. Number Reduction
  • Java集合面试题
  • Python 编程基础 | 第三章-数据类型 | 3.5、列表
  • Spring Cloud Zuul 基本原理