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

PostgreSQL的备份方式

PostgreSQL 提供多种方式进行备份,适用于不同需求的场景。常用的备份方法如下:


1. 逻辑备份(pg_dump 和 pg_dumpall)

1.1 使用 pg_dump 备份单个数据库

pg_dump 是 PostgreSQL 内置的逻辑备份工具,可以将数据库导出为 SQL 脚本或二进制文件。

备份命令
  • 备份为 SQL 文件

    pg_dump -U username -d database_name -F p -f /path/to/backup.sql
    

    参数说明:

    • -U: 用户名。
    • -d: 数据库名称。
    • -F p: 输出为纯文本格式(Plain text)。
    • -f: 指定备份文件路径。
  • 备份为压缩文件

    pg_dump -U username -d database_name -F c -f /path/to/backup.dump
    

    参数说明:

    • -F c: 压缩格式(Custom format)。
    • 压缩格式可以使用 pg_restore 还原。
还原命令
  • 对于 SQL 文件:

    psql -U username -d new_database_name -f /path/to/backup.sql
    
  • 对于压缩文件:

    pg_restore -U username -d new_database_name /path/to/backup.dump
    

1.2 使用 pg_dumpall 备份所有数据库

pg_dumpall 用于备份整个 PostgreSQL 实例(包括所有数据库和全局对象,如角色、权限等)。

备份命令
pg_dumpall -U username -f /path/to/backup_all.sql
还原命令
psql -U username -f /path/to/backup_all.sql

2. 物理备份(pg_basebackup)

2.1 使用 pg_basebackup

pg_basebackup 是 PostgreSQL 提供的物理备份工具,适合对数据库进行完整二进制备份。

备份命令
pg_basebackup -U replication_user -D /path/to/backup_directory -Fp -Xs -P

参数说明:

  • -U: 备份用户(需要配置 replication 权限)。
  • -D: 目标备份目录。
  • -Fp: 文件模式(Plain format)。
  • -Xs: 包含 WAL 日志。
  • -P: 显示进度。
还原步骤
  1. 停止 PostgreSQL 服务:

    systemctl stop postgresql
    
  2. 将备份数据复制到 PostgreSQL 数据目录:

    cp -r /path/to/backup_directory/* /var/lib/pgsql/data/
    
  3. 启动 PostgreSQL 服务:

    systemctl start postgresql
    

3. 归档日志备份(WAL 日志)

归档日志备份适用于需要时间点恢复 (Point-in-Time Recovery, PITR) 的场景。

步骤
  1. 配置归档模式
    编辑 postgresql.conf

    archive_mode = on
    archive_command = 'cp %p /path/to/archive/%f'
    
  2. 重启 PostgreSQL

    systemctl restart postgresql
    
  3. 定期备份归档日志
    配置脚本定期复制 /path/to/archive/ 目录。

  4. 使用日志和备份恢复
    在需要恢复时,结合初始物理备份和归档日志文件执行恢复。


4. 其他备份工具

4.1 Barman

Barman 是社区维护的 PostgreSQL 专用备份工具,支持物理备份和时间点恢复。

备份命令
barman backup server_name
恢复命令
barman recover server_name backup_id /path/to/restore_directory

4.2 WAL-G

WAL-G 是 PostgreSQL 的现代备份工具,支持增量备份和快速恢复,常用于云环境。


最佳实践

  1. 定期备份

    • 每天/每周使用 pg_dumppg_basebackup
    • 实现自动化备份脚本。
  2. 启用归档日志

    • 保证 WAL 日志可用于时间点恢复。
  3. 多地存储备份

    • 本地存储 + 云存储(如 S3、Google Cloud Storage)。
  4. 测试还原流程

    • 定期验证备份文件的完整性。
    • 演练灾难恢复。
  5. 监控备份

    • 结合监控工具(如 Zabbix、Prometheus)监控备份进度和状态。

按照这些方式定期备份 PostgreSQL 数据库,可以最大程度地保障数据的安全和可恢复性。

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

相关文章:

  • Springboot 3项目整合Knife4j接口文档(接口分组详细教程)
  • 深入解析 Conda 安装的默认依赖包及其作用:conda create安装了哪些包(中英双语)
  • Redis核心技术知识点全集
  • 【Unity3D】ECS入门学习(九)SystemBase
  • 【Triton-ONNX】如何使用 ONNX 模型服务与 Triton 通信执行推理任务上-Triton快速开始
  • CertiK《Hack3d:2024年度安全报告》(附报告全文链接)
  • TIOBE 指数 12 月排行榜公布,VB.Net排行第九
  • 【网络协议】开放式最短路径优先协议OSPF详解(一)
  • 嵌入式Linux驱动开发的基本知识(驱动程序的本质、常见的设备类型、设备号的本质理解、设备实例的注册过程)
  • 爱死机第四季(秘密关卡)4KHDR国语字幕
  • kubelet状态错误报错
  • <div>{{ $t(“collectionPlan“) }}</div> 中的$t是什么
  • [C++刷题] 求回文素数
  • SQLALchemy如何将SQL语句编译为特定数据库方言
  • [卫星遥感] 解密卫星目标跟踪:挑战与突破的深度剖析
  • I2C(一):存储器模式:stm32作为主机对AT24C02写读数据
  • scrapy 教程
  • 2025元旦源码免费送
  • 高级架构五 设计模式
  • RFID手持机与RFID工业平板在仓储物流管理系统中的选型
  • IoC设计模式详解:控制反转的核心思想
  • 《云原生安全攻防》-- K8s安全配置:CIS安全基准与kube-bench工具
  • LINUX下载编译gtk
  • 基于VSCode软件框架的RISC-V IDE MRS2正式上线发布
  • AWS re:Invent 2024 - Dr. Werner Vogels 主题演讲
  • 前端小案例——520表白信封
  • FPGA随记——过约束
  • 如何利用云计算进行灾难恢复?
  • 【华为OD-E卷 - 九宫格按键输入 100分(python、java、c++、js、c)】
  • 基于AI大模型的医院SOP优化:架构、实践与展望