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

【PostgreSQL】不开启归档模式,是否会影响主从库备份?

PostgreSQL 不开启归档模式(archive_mode = off不会直接影响基于流复制(Streaming Replication)的主从备份,但可能会在特定场景下影响复制的健壮性和恢复能力。以下是详细分析:

1. 流复制的核心机制

  • 流复制的工作原理
    主库将生成的 WAL(Write-Ahead Log)记录通过 TCP 连接实时传输给备库,备库持续重放这些日志以保持数据同步。
    关键点:流复制的数据传输不依赖归档模式,直接通过 WAL 流完成。

  • 不开启归档模式的影响
    只要主从之间的网络稳定,且备库能及时接收并应用 WAL,流复制仍能正常工作。归档模式的开启与否不影响流复制的核心流程


2. 潜在风险场景

尽管流复制不强制要求归档模式,但以下场景可能因未开启归档模式导致问题:

场景 1:主从延迟过高
  • 若备库因故障或高负载长时间落后于主库,主库可能会删除尚未传输的旧 WAL 文件(由 wal_keep_size 参数控制保留量)。
  • 未开启归档模式:主库不会保留这些 WAL 文件,备库可能因无法获取缺失的 WAL 而中断复制。
  • 解决方案
    增大 wal_keep_size 或启用归档模式,确保备库能从归档目录中获取历史 WAL。
场景 2:备库重建
  • 若需重新搭建备库(例如主库数据损坏),通常需要基于基础备份(pg_basebackup)和归档的 WAL 文件恢复。
  • 未开启归档模式:缺少历史 WAL 文件,可能无法完成备库重建。

扩展阅读:PostgreSql 主从数据库备份原理


3. 归档模式的作用

  • 核心功能:将 WAL 文件持久化到外部存储(如另一台服务器、云存储),用于:
    1. 时间点恢复(PITR):恢复到特定时间点的数据状态。
    2. 增强复制健壮性:为流复制提供 WAL 文件的备份来源。
    3. 长期数据保护:防止 WAL 文件被主库自动删除。

扩展阅读:PostgreSql 归档模式详解:配置、管理与清理


4. 结论与建议

  • 主从备份是否受影响
    • 流复制:不受直接影响,可正常运行。
    • 归档复制(Log-Shipping):必须开启归档模式。
  • 建议配置
    • 若仅依赖流复制,可不开启归档模式,但需合理设置 wal_keep_size
    • 若需要高可用性、灾备恢复或备库重建能力,强烈建议开启归档模式
    • 使用工具(如 pgBackRestWAL-G)同时管理归档和备份,提升数据安全性。

配置示例

# postgresql.conf
wal_level = replica             # 启用足够的 WAL 日志
max_wal_senders = 5             # 允许流复制连接
archive_mode = on               # 开启归档模式(可选但建议)
archive_command = 'cp %p /path/to/archive/%f'  # 归档命令(如启用归档模式)
wal_keep_size = 1GB             # 保留最近的 WAL 文件量(防止备库延迟)
http://www.xdnf.cn/news/365257.html

相关文章:

  • OrangePi Zero 3学习笔记(Android篇)4 - eudev编译(获取libudev.so)
  • 边界网关协议 - BGP【高级】
  • 蓝绿激光对潜通信介绍
  • 【官方题解】StarryCoding 入门教育赛 2 | acm | 蓝桥杯 | 新手入门
  • 画家沈燕的山水实验:在传统皴法里植入时代密码
  • mysql性能提升方法大汇总
  • 【kafla扫盲】FROM GPT
  • 基于51单片机步进电机控制—9个等级
  • async/await 原理揭秘
  • Windows11下通过Docker安装Redis
  • USB学习【4】协议层数据格式
  • C++八股 —— 函数指针与指针函数
  • PPI-ID: 德克萨斯大学研究团队最新款蛋白-蛋白互作(PPI)预测工具上线
  • Ascend的aclgraph(一)aclgraph是什么?torchair又是怎么成图的?
  • 2025年 全新 AI 编程工具 Cursor 安装使用教程
  • 2025数维杯数学建模C题完整限量论文:清明时节雨纷纷,何处踏青不误春?
  • 空间复杂度** 与 **所需辅助空间**
  • 33、前台搜索功能怎么实现?
  • 基环树(模板) 2876. 有向图访问计数
  • Dp通用套路(闫式)
  • OPENSSL-1.1.1的使用及注意事项
  • Qt 无边框窗口,支持贴边分屏
  • 大某麦演唱会门票如何自动抢
  • 高尔夫基本知识及规则·棒球1号位
  • PHP8报:Unable to load dynamic library ‘zip.so’ 错误
  • Xterminal(或 X Terminal)通常指一类现代化的终端工具 工具介绍
  • 攻防演练 | 关于蓝队攻击研判的3大要点解读
  • 分治算法-leetcode148题
  • archlinux 详解系统层面
  • RISC-V AIA SPEC学习(五)