运维

运维

Products

当前位置:首页 > 运维 >

配置Debian PostgreSQL主从复制,轻松实现数据备份与高可用!

96SEO 2026-05-03 06:01 5


Debian PostgreSQL如何配置主从复制

前言:为何要在 Debian 上玩转 PostgreSQL 主从复制?

如果你已经在生产环境里折腾了几年的数据库, 突然发现一次硬盘崩溃就把业务拉进了深渊,那种心情……简直比看完一部烂片还难受。于是 高可用容灾备份便成了每个 DBA 必不可少的“灵魂伴侣”。在 Debian 系统上部署 PostgreSQL 的流复制, 不仅能让你的数据实时同步,还能在主库挂掉的瞬间把读请求无缝切到从库,真正做到“一键恢复”。下面我将用最接地气的语言、配合大量代码示例,带你一步步完成这套“魔法”。准备好咖啡和键盘了吗?让我们开始吧,没耳听。。

一、 环境准备与前置检查

项目要求
操作系统Debian 10/11/12
PostgreSQL 版本12 以上
网络连通性主从机器之间 TCP 5432 端口必须畅通
系统时间同步NTP 同步,否则 WAL 时间戳会闹笑话
磁盘空间至少保留 5GB 的 WAL 日志存档空间

公正地讲... 小贴士:如果你是第一次踩踏 Linux 防火墙,别忘了先把 ufw 或 iptables 给关掉——不然连不上也只能怪自己。

1.1 安装基础工具 & 同步时间

# 更新软件源
sudo apt update && sudo apt upgrade -y
# 安装 NTP
sudo apt install -y ntp
sudo systemctl enable --now ntp

1.2 安装 PostgreSQL

# 添加官方仓库
echo "deb http://apt.postgresql.org/pub/repos/apt $-pgdg main" \
| sudo tee /etc/apt/sources.list.d/pgdg.list
wget --quiet -O - https://www.postgresql.org/media/keys/ACCC4CF8.asc \
| sudo apt-key add -
sudo apt update
sudo apt install -y postgresql-14 postgresql-contrib

安装完毕后用 psql --version 确认两台机器的版本保持一致。

二、 配置主服务器——让它成为数据的“大老板”

2.1 编辑 postgresql.conf

打开位于 /etc/postgresql/14/main/postgresql.conf 的配置文件,将以下关键参数调好:,太刺激了。

# Listen on all interfaces 
listen_addresses = '*'
# 开启流复制所需的 WAL 设置
wal_level = replica               # 必须是 replica 或 logical
max_wal_senders = 10             # 根据从库数量酌情增减
wal_keep_segments = 64           # 保留足够的 WAL 文件防止落后太多
# 热备模式,让从库可以接受只读查询
hot_standby = on
# 合理设置 checkpoint 参数,防止磁盘突发写入导致卡顿
checkpoint_timeout = 5min
checkpoint_completion_target = 0.9
max_replication_slots = 5        # 若使用逻辑复制,可提前预留槽位

2.2 配置 pg_hba.conf —— 放行复制专用账号

在同目录下的 /etc/postgresql/1 不忍卒读。 4/main/pg_hba.conf 添加一行:

# 主库允许 replicator 从任意 IP 同步数据
host    replication     replicator      192.168.1.0/24          md5
host    all             all             127.0.0.1/32            trust   # 本地连接保持简单
host    all             all             ::1/128                 trust

2.3 创建复制专用用户

# 切换到 postgres 系统用户
sudo -i -u postgres
# 创建一个只用于复制的角色,密码自行设定
createuser --replication --login --no-superuser --no-createdb \
            --no-createrole replicator
psql -c "ALTER USER replicator WITH ENCRYPTED PASSWORD 'YourStrongPass!';"
\q
exit   # 返回普通用户

三、配置从服务器——让它成为可靠的“影子”

3.1 停止 PostgreSQL 服务,为恢复做准备

# 在从库上施行:
sudo systemctl stop postgresql@14-main   # 确保服务已彻底停止
sudo rm -rf /var/lib/postgresql/14/main/*   # 清空旧数据目录

3.2 使用 pg_basebackup 拉取主库全量快照

# 施行一次完整基线备份并压缩归档:
sudo -u postgres pg_basebackup \
   -h 主库IP地址 \
   -D /var/lib/postgresql/14/main \
   -U replicator \
   -W \
   -P \
   --wal-method=stream \
   --format=tar \
   --gzip
# 解压缩得到的数据目录:
cd /var/lib/postgresql/14/main && tar xzf *.tar.gz && rm *.tar.gz

3.3 编写 recovery.conf

A) 在 data 目录下创建一个空文件表示该实例是 standby:,捡漏。

# touch /var/lib/postgresql/14/main/standby.signal

B) 再编辑同目录下的 /etc/postgresql/14 至于吗? /main/postgresql.conf , 加入以下内容:

也是没谁了。 # 与主库保持心跳链接的信息: primary_conninfo = 'host=主库IP地址 port=5432 user=replicator password=YourStrongPass!'

我悟了。 triggerfile = '/tmp/promoteto_master.trigger'

hot_standby = on

archivemode = on archivecommand = 'cp %p /var/lib/postgresql/14/walarchive/%f' archivetimeout = 60s,我是深有体会。

常见坑点速查表:

PITFALL CURE "could not connect to server: Connection refused"- 检查 listenaddresses 是否为 '*' - 防火墙是否放行端口5432 - 主机名解析是否正确。 "WAL archiving failed"- 确认 archivecommand 路径存在且可写 - 检查磁盘配额。 "replication slot does not exist"- 在主库创建对应 slot: SELECT * FROM pgcreatephysicalreplicationslot; "restartpoint after recovery is required"- 确认 standby.signal 存在;若仍报错,请删除 data 并重新 basebackup。 "duplicate key value violates unique constraint"- 数据冲突通常是主要原因是手动修改了 from‑standby 的表结构,请保持两端 schema 一致,不夸张地说...。

四、 启动服务并验证同步状态

4.1 启动两台机器上的 PostgreSQL 服务

# 主库: sudo systemctl enabl 改进一下。 e --now postgresql@14-main

4.2 在主库创建测试数据

# 切换到 postgres 用户并进入 psql:
sudo -i -u postgres psql

CREATE DATABASE demo; \c demo

CREATE TABLE notes ( id SERIAL PRIMARY KEY, content TEXT NOT NULL, created_at TIMESTAMP DEFAULT now ); INSERT INTO notes VALUES , ; \q

4.3 在从库检查同步情况

SELECT * FROM notes;

If you see two rows inserted earlier, 🎉恭喜,你已经成功完成了流复制!若还没有同步,请耐心等几秒钟或查看日志排查延迟原因,来日方长。。

五、 监控、故障转移与日常运维小技巧

5.1 使用 pg_stat_replication 查看实时状态

# 在主库运行: SELECT pid, clientaddr, state, syncstate, sentlsn, writelsn, flushlsn, replaylsn, 佛系。 now - backendstart AS uptime, now - pglastxactreplaytimestamp AS lagtime FROM pgstatreplication;

看好你哦! This query gives you a quick glance at latency and wher standby is in sync.

5.2 自动化故障转移方案简述

PATONRI:负责监控 primary 状态,一旦检测到宕机,会自动提升某个 standby 为新 primary;一边更新 DNS 或 VIP。 EETCD:分布式 KV 存储,用来保存 leader 锁信息;确保集群只有唯一一个 leader。 Nginx/Haproxy:前端负载均衡层, 薅羊毛。 只向 VIP 提供服务入口,让客户端透明感知故障切换。 SCRIPT 示例:下面是一段简易 Bash 脚本, 用来手动触发 promotion: #!/bin/bash TRIGGER=/tmp/promotetomaster.trigger

if ; n sudo touch $TRIGGER echo "Trigger file created – standby will promote on next restart." else echo "Trigger already exists." fi 运行完毕后只需重启 Postgres 即可完成提升:

  • `sudo systemctl restart postgresql@14-main` — 从此刻起,它已经是新 master! 🚀
    • 6️⃣ 小结 & 心得体会 🚦🚦🚦‍♀️‍♂️‍♀️‍♂️‍♀️‍♂️​​​​​​​​​​ ​ ​ ​ ​ ​ ​ ​  ​​​​​​​​​​​​​​​​​​​​​​​​​​ ​​​​ ​​​​​ 本文约 字, 太离谱了。 如需更细致指导,可关注我的博客或直接留言交流~


      标签: debian

      SEO优化服务概述

      作为专业的SEO优化服务提供商,我们致力于通过科学、系统的搜索引擎优化策略,帮助企业在百度、Google等搜索引擎中获得更高的排名和流量。我们的服务涵盖网站结构优化、内容优化、技术SEO和链接建设等多个维度。

      百度官方合作伙伴 白帽SEO技术 数据驱动优化 效果长期稳定

      SEO优化核心服务

      网站技术SEO

      • 网站结构优化 - 提升网站爬虫可访问性
      • 页面速度优化 - 缩短加载时间,提高用户体验
      • 移动端适配 - 确保移动设备友好性
      • HTTPS安全协议 - 提升网站安全性与信任度
      • 结构化数据标记 - 增强搜索结果显示效果

      内容优化服务

      • 关键词研究与布局 - 精准定位目标关键词
      • 高质量内容创作 - 原创、专业、有价值的内容
      • Meta标签优化 - 提升点击率和相关性
      • 内容更新策略 - 保持网站内容新鲜度
      • 多媒体内容优化 - 图片、视频SEO优化

      外链建设策略

      • 高质量外链获取 - 权威网站链接建设
      • 品牌提及监控 - 追踪品牌在线曝光
      • 行业目录提交 - 提升网站基础权威
      • 社交媒体整合 - 增强内容传播力
      • 链接质量分析 - 避免低质量链接风险

      SEO服务方案对比

      服务项目 基础套餐 标准套餐 高级定制
      关键词优化数量 10-20个核心词 30-50个核心词+长尾词 80-150个全方位覆盖
      内容优化 基础页面优化 全站内容优化+每月5篇原创 个性化内容策略+每月15篇原创
      技术SEO 基本技术检查 全面技术优化+移动适配 深度技术重构+性能优化
      外链建设 每月5-10条 每月20-30条高质量外链 每月50+条多渠道外链
      数据报告 月度基础报告 双周详细报告+分析 每周深度报告+策略调整
      效果保障 3-6个月见效 2-4个月见效 1-3个月快速见效

      SEO优化实施流程

      我们的SEO优化服务遵循科学严谨的流程,确保每一步都基于数据分析和行业最佳实践:

      1

      网站诊断分析

      全面检测网站技术问题、内容质量、竞争对手情况,制定个性化优化方案。

      2

      关键词策略制定

      基于用户搜索意图和商业目标,制定全面的关键词矩阵和布局策略。

      3

      技术优化实施

      解决网站技术问题,优化网站结构,提升页面速度和移动端体验。

      4

      内容优化建设

      创作高质量原创内容,优化现有页面,建立内容更新机制。

      5

      外链建设推广

      获取高质量外部链接,建立品牌在线影响力,提升网站权威度。

      6

      数据监控调整

      持续监控排名、流量和转化数据,根据效果调整优化策略。

      SEO优化常见问题

      SEO优化一般需要多长时间才能看到效果?
      SEO是一个渐进的过程,通常需要3-6个月才能看到明显效果。具体时间取决于网站现状、竞争程度和优化强度。我们的标准套餐一般在2-4个月内开始显现效果,高级定制方案可能在1-3个月内就能看到初步成果。
      你们使用白帽SEO技术还是黑帽技术?
      我们始终坚持使用白帽SEO技术,遵循搜索引擎的官方指南。我们的优化策略注重长期效果和可持续性,绝不使用任何可能导致网站被惩罚的违规手段。作为百度官方合作伙伴,我们承诺提供安全、合规的SEO服务。
      SEO优化后效果能持续多久?
      通过我们的白帽SEO策略获得的排名和流量具有长期稳定性。一旦网站达到理想排名,只需适当的维护和更新,效果可以持续数年。我们提供优化后维护服务,确保您的网站长期保持竞争优势。
      你们提供SEO优化效果保障吗?
      我们提供基于数据的SEO效果承诺。根据服务套餐不同,我们承诺在约定时间内将核心关键词优化到指定排名位置,或实现约定的自然流量增长目标。所有承诺都会在服务合同中明确约定,并提供详细的KPI衡量标准。

      SEO优化效果数据

      基于我们服务的客户数据统计,平均优化效果如下:

      +85%
      自然搜索流量提升
      +120%
      关键词排名数量
      +60%
      网站转化率提升
      3-6月
      平均见效周期

      行业案例 - 制造业

      • 优化前:日均自然流量120,核心词无排名
      • 优化6个月后:日均自然流量950,15个核心词首页排名
      • 效果提升:流量增长692%,询盘量增加320%

      行业案例 - 电商

      • 优化前:月均自然订单50单,转化率1.2%
      • 优化4个月后:月均自然订单210单,转化率2.8%
      • 效果提升:订单增长320%,转化率提升133%

      行业案例 - 教育

      • 优化前:月均咨询量35个,主要依赖付费广告
      • 优化5个月后:月均咨询量180个,自然流量占比65%
      • 效果提升:咨询量增长414%,营销成本降低57%

      为什么选择我们的SEO服务

      专业团队

      • 10年以上SEO经验专家带队
      • 百度、Google认证工程师
      • 内容创作、技术开发、数据分析多领域团队
      • 持续培训保持技术领先

      数据驱动

      • 自主研发SEO分析工具
      • 实时排名监控系统
      • 竞争对手深度分析
      • 效果可视化报告

      透明合作

      • 清晰的服务内容和价格
      • 定期进展汇报和沟通
      • 效果数据实时可查
      • 灵活的合同条款

      我们的SEO服务理念

      我们坚信,真正的SEO优化不仅仅是追求排名,而是通过提供优质内容、优化用户体验、建立网站权威,最终实现可持续的业务增长。我们的目标是与客户建立长期合作关系,共同成长。

      提交需求或反馈

      Demand feedback