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

PostgreSQL 主从集群搭建

下面是 PostgreSQL 主从复制(Streaming Replication)环境的安装与配置指南,适合在两台或多台服务器之间构建一主一从(或一主多从)的高可用读写分离系统。


环境准备

角色主机名/IP说明
主库192.168.1.10可读写,负责复制源
从库192.168.1.11只读,从主库同步数据

推荐 PostgreSQL 版本一致,例如 15.x;操作系统为 Ubuntu/CentOS 均可。


一、安装 PostgreSQL(主从都要装)

以 Ubuntu 为例:

sudo apt update
sudo apt install postgresql postgresql-contrib -y

CentOS:

sudo yum install -y postgresql-server postgresql-contrib

初始化数据库(如未自动初始化):

sudo -u postgres /usr/pgsql-15/bin/initdb -D /var/lib/pgsql/15/data

二、配置主库(192.168.1.10)

1. 修改 postgresql.conf

路径通常为 /etc/postgresql/15/main/postgresql.conf/var/lib/pgsql/15/data/postgresql.conf

# 启用 WAL 日志并设置参数
wal_level = replica
max_wal_senders = 10
wal_keep_size = 128MB
hot_standby = on
listen_addresses = '*'

2. 修改 pg_hba.conf(允许从库连接复制)

# 添加允许从库复制连接
host    replication     all     192.168.1.11/32     md5

3. 重启主库

sudo systemctl restart postgresql

三、从库配置(192.168.1.11)

1. 停止 PostgreSQL 服务并清空数据目录

sudo systemctl stop postgresql
rm -rf /var/lib/postgresql/15/main/*

2. 使用 pg_basebackup 拉取主库数据

pg_basebackup -h 192.168.1.10 -D /var/lib/postgresql/15/main -U postgres -P -R

说明:

  • -h:主库 IP
  • -D:写入数据目录
  • -U:复制用户(需先创建)
  • -R:自动创建 standby.signalprimary_conninfo

如果提示用户不存在,请先在主库执行:

CREATE ROLE repl WITH REPLICATION LOGIN PASSWORD 'replpass';

并确保 pg_hba.conf 中允许该 IP 使用此用户连接。

3. 修改复制用户密码(如果 -R 中未设置)

编辑 postgresql.conf 确保:

primary_conninfo = 'host=192.168.1.10 port=5432 user=repl password=replpass'

四、启动从库

sudo systemctl start postgresql

检查日志 /var/log/postgresql/postgresql-15-main.log 是否同步成功。


五、验证主从同步

主库执行:

SELECT * FROM pg_stat_replication;

从库查看:

SELECT pg_is_in_recovery();  -- 返回 true 表示是从库

六、主从读写测试建议

操作主库从库
创建表/插入数据✅ 支持❌ 禁止
查询数据✅ 支持✅ 支持
自动同步✅ 向从库推送✅ 被动接收

七、开机自启动设置(主从)

sudo systemctl enable postgresql

八、参考目录结构(Debian/Ubuntu)

配置文件路径
postgresql.conf/etc/postgresql/15/main/
pg_hba.conf/etc/postgresql/15/main/
数据目录/var/lib/postgresql/15/main/
日志文件/var/log/postgresql/postgresql-15-main.log

常见问题排查

问题解决办法
pg_basebackup 报权限错误主库需创建 replication 权限用户
从库无法连接主库检查主库防火墙 / pg_hba.conf
主库 pg_stat_replication 为空检查从库连接信息是否正确
写入从库失败合理,PostgreSQL 只读备库默认禁止写入

高级扩展建议

目标建议工具
自动故障切换repmgr, Patroni
虚拟 IP 高可用切换Keepalived + VIP
读写分离中间件pgpool-II
多从、链式复制支持
双机部署脚本化自动搭建Ansible/脚本工具

http://www.lqws.cn/news/547183.html

相关文章:

  • 杭州市长姚高员带队调研景联文科技,听取高质量数据集建设情况
  • [特殊字符] Python 批量合并 Word 表格中重复单元格教程(收货记录案例实战)
  • 从零开始的二三维CAD|CAE轻量级软件开发:学习以及研发,Gmsh的脚本编辑器设计!
  • python 脚本 遍历目录,并把目录下的非utf-8文件改成utf8
  • 16.2 Docker多阶段构建实战:LanguageMentor镜像瘦身40%,支持500+并发1.2秒响应!
  • 02【C++ 入门基础】标准输入输出初识/缺省参数
  • Qt 与 Halcon 联合开发六:基于海康SDK设计完整的相机类【附源码】
  • 【Elasticsearch】Linux环境下安装Elasticsearch
  • git rebase -i 详解
  • 微服务中解决高并发问题的不同方法!
  • 未来蓝图:引领能源数字化新浪潮
  • html制作一个简单的表单
  • 每天一个前端小知识 Day 14 - 前端状态管理深入实践
  • [1-01-01].第27节:常用类 - 包装类
  • 26考研|数学分析:隐函数定理及其应用
  • 官方App Store,直链下载macOS ,无需Apple ID,macOS10.10以上.
  • php flush实时输出线上环境好使,本地环境等待一段时间后一次性输出结果的原因
  • 跨芯片 AI 算子库 FlagGems 正式加入PyTorch 基金会生态项目体系
  • MyBatis中的SQL理解
  • uniappx 安卓app项目本地打包运行,腾讯地图报错:‘鉴权失败,请检查你的key‘
  • Unity性能优化-渲染模块(1)-CPU侧(1)-优化方向
  • 基于springboot的火锅店点餐系统
  • 分布式存储架构的优势
  • 河北对口计算机高考C#笔记(2026高考适用)---完结版~~~~
  • GPS不只是导航,实时定位追踪系统如何玩转智能时代?
  • 深度学习框架入门指南:PyTorch 核心实战
  • 第N5周:Pytorch文本分类入门
  • 使用GDAL库统计不同分区内的灾害点分布情况,计算灾害相对密度等统计指标
  • Spring Boot 3.2.11 Swagger版本推荐
  • Python 数据分析与可视化 Day 9 - 缺失值与异常值处理技巧