PostgreSQL

关注公众号 jb51net

关闭
首页 > 数据库 > PostgreSQL > PostgreSQL数据库备份与恢复

PostgreSQL数据库备份与恢复的四种办法

作者:xiongood

在数据为王的时代,数据库中存储的信息堪称企业的生命线,而PostgreSQL作为一款广泛应用的开源数据库,学会如何妥善进行备份与恢复操作,是每个开发者与运维人员必备的技能,今天,咱们就深入探究一下PostgreSQL相关的备份恢复策略,并附上丰富的代码示例

在数据为王的时代,数据库中存储的信息堪称企业的生命线,而PostgreSQL作为一款广泛应用的开源数据库,学会如何妥善进行备份与恢复操作,是每个开发者与运维人员必备的技能。今天,咱们就深入探究一下PostgreSQL相关的备份恢复策略,并附上丰富的代码示例。

一、pg_dump:逻辑备份的利器

pg_dump是PostgreSQL自带的用于生成数据库逻辑备份的工具。它能把数据库的结构以及数据,以SQL脚本的形式导出,方便在其他环境里重建。

  1. 备份单个数据库 假设我们有个名为test_db的数据库,要将它完整备份下来,操作如下:
pg_dump -U your_username -Fc test_db > test_db.dump

这里,-U指定用户名,-Fc表示以自定义的压缩二进制格式导出,这种格式备份速度较快,而且生成的文件体积较小 。最后将备份内容重定向到test_db.dump文件中。

  1. 备份指定表 要是只想备份数据库里的部分表,例如test_db中的users表和orders表:
pg_dump -U your_username -t users -t orders -Fc test_db > partial_dump.dump

-t参数用来指定需要备份的表名,可以多次使用这个参数来添加多个目标表。

二、pg_restore:逻辑备份的恢复操作

有了备份文件,借助pg_restore就能让数据起死回生。

  1. 恢复完整数据库 先创建一个空的目标数据库,假设叫new_test_db,然后执行恢复:
createdb -U your_username new_test_db
pg_restore -U your_username -d new_test_db test_db.dump

createdb用于创建新数据库,-d参数在pg_restore里表示目标数据库,按照备份文件test_db.dump中的指令,把数据和结构填充进新的new_test_db数据库。

  1. 恢复部分表 如果只想恢复之前备份里的部分表,例如只恢复users表:
pg_restore -U your_username -d new_test_db -t users test_db.dump

-t参数的含义和备份时一致,精准定位到需要恢复的表。

三、pg_basebackup:物理备份的实现

物理备份会直接拷贝数据库文件,相较于逻辑备份,速度更快,适合大型数据库。

  1. 基础物理备份 以超级用户身份执行以下命令:
pg_basebackup -D /path/to/backup -U your_superuser -P

-D指定备份文件存放的目录,-U是超级用户用户名,-P 会显示备份进度,让我们能实时知晓备份状态。不过物理备份要注意,目标目录必须为空,而且在备份期间数据库读写操作尽量减少,避免数据不一致。

  1. 增量物理备份 先完成一次基础物理备份,后续增量备份基于这个基础来做。我们要记录下基础备份的 WAL(Write-Ahead Logging,预写式日志)文件位置。增量备份时:
pg_basebackup -D /path/to/incremental_backup -U your_superuser -P -X stream -C -R \
--checkpoint=fast --target-wal-segment-size=16MB \
--write-recovery-conf --recovery-target-time='2025-01-15 12:00:00'

-X stream开启流模式来传输WAL日志,-C表示在备份结束后清理不再需要的WAL段,-R自动生成恢复配置文件,后面几个参数用于精细调整备份的检查点和目标WAL段大小,--recovery-target-time则设定恢复到的时间点。

四、基于WAL日志的恢复

WAL日志是PostgreSQL物理恢复的关键,就算数据库出现故障,只要WAL日志完整,就能恢复到故障前的状态。

假设数据库崩溃了,先把物理备份文件拷贝到合适位置,然后利用WAL日志恢复:

cp -R /path/to/backup /var/lib/postgresql/data
# 找到相关WAL日志,假设存放在 /var/lib/postgresql/wal_logs
cp /var/lib/postgresql/wal_logs/*.log /var/lib/postgresql/data/pg_wal
# 启动PostgreSQL服务,它会自动根据WAL日志恢复数据
sudo systemctl start postgresql

五、总结

掌握这些备份与恢复手段,就像是给PostgreSQL数据库穿上了坚固的铠甲,无论遭遇意外删除、硬件故障还是其他数据危机,都能沉着应对,守护数据资产的安全与完整。

到此这篇关于PostgreSQL数据库备份与恢复的四种办法的文章就介绍到这了,更多相关PostgreSQL数据库备份与恢复内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文