PostgreSQL数据库备份的几种实现方法

 更新时间:2025年06月15日 11:13:35   作者:雪花凌落的盛夏  
本文主要介绍了PostgreSQL数据库备份的几种实现方法,包括pg_dump和pg_dumpall是PostgreSQL备份工具,前者备份单数据库,后者备份整个集群,感兴趣的可以了解一下

pg_dump 和 pg_dumpall

在 PostgreSQL 中,pg_dump 和 pg_dumpall 是两个常用的备份工具,分别用于逻辑备份单个数据库和整个数据库集群。

检查pg_dump 和 pg_dumpall命令是否可用

su - postgres
pg_dump --version
pg_dumpall --version

在这里插入图片描述

使用 pg_dump 备份单个数据库

pg_dump -U <用户名> -h <主机名> -p <端口号> -F <格式> -f <输出文件路径> <数据库名>

参数:

  • -U:指定数据库用户名。
  • -h:指定数据库主机地址(默认 localhost)。
  • -p:指定数据库端口(默认 5432)。
  • -F:指定备份格式:
    • plain(默认):生成 SQL 脚本文件。
    • c:自定义格式(支持压缩,需用 pg_restore 恢复)。
    • d:目录格式(支持并行备份)。
    • t:tar 格式。
  • -f:指定输出文件路径。
  • --schema-only:仅备份表结构(不包含数据)。
  • --data-only:仅备份数据(不包含表结构)。
  • -t <表名>:备份特定表。
  • -j <并行任务数>:并行备份(适用于大数据库)。

示例

备份整个数据库为 SQL 文件:

pg_dump -U postgres -h localhost -p 5432 -F p -f /path/to/backup.sql mydb
  • -F p 表示输出为普通 SQL 文件。
  • mydb 是要备份的数据库名。

备份整个数据库为自定义格式(支持压缩):

pg_dump -U postgres -h localhost -p 5432 -F c -f /path/to/backup.custom mydb
  • -F c 表示输出为自定义格式(需用 pg_restore 恢复)。

备份特定表:

pg_dump -U postgres -h localhost -p 5432 -F p -t users -f /path/to/users_backup.sql mydb
  • -t users 表示仅备份 users 表。

仅备份表结构:

pg_dump -U postgres -h localhost -p 5432 --schema-only -f /path/to/schema.sql mydb

仅备份数据(不包含表结构):

pg_dump -U postgres -h localhost -p 5432 --data-only -f /path/to/data.sql mydb

使用 pg_dumpall 备份整个数据库集群

基本用法

pg_dumpall 用于备份整个 PostgreSQL 集群,包括所有数据库、角色(用户)、表空间等全局对象。

命令格式:

pg_dumpall -U <用户名> -h <主机名> -p <端口号> -f <输出文件路径> [选项]

参数:

  • -g:仅备份全局对象(角色、表空间等)。
  • -c:在备份中包含删除数据库的命令(用于恢复时清理旧数据)。
  • -v:启用详细模式(显示备份过程)。

示例

备份整个集群:

pg_dumpall -U postgres -h localhost -p 5432 -f /path/to/cluster_backup.sql
  • 生成的 SQL 文件包含所有数据库、角色和表空间。

仅备份全局对象(角色、表空间):

pg_dumpall -U postgres -h localhost -p 5432 -g -f /path/to/globals.sql

备份整个集群并包含清理命令:

pg_dumpall -U postgres -h localhost -p 5432 -c -f /path/to/cluster_backup.sql

恢复备份

恢复 pg_dump 备份

SQL 文件恢复:

psql -U <用户名> -h <主机名> -d <目标数据库> -f <备份文件路径>

示例:

psql -U postgres -h localhost -d mydb -f /path/to/backup.sql

自定义格式恢复:

pg_restore -U <用户名> -h <主机名> -d <目标数据库> <备份文件路径>

示例:

pg_restore -U postgres -h localhost -d mydb /path/to/backup.custom

恢复 pg_dumpall 备份

恢复整个集群备份:

psql -U postgres -h localhost -d postgres -f /path/to/cluster_backup.sql

需以 postgres 用户连接到默认数据库(如 postgres),因为恢复过程中会创建其他数据库。

恢复全局对象备份:

psql -U postgres -h localhost -d postgres -f /path/to/globals.sql

Tips

权限要求:

  • pg_dump 需要对目标数据库有读取权限。
  • pg_dumpall 需要超级用户权限(以备份角色和表空间)。

备份格式选择:

  • 如果需要灵活的恢复选项(如选择性恢复表),建议使用自定义格式(-F c)。
  • 如果需要快速恢复,SQL 文件可能更直接。

并行备份:

  • 对大型数据库,使用 -j <并行任务数> 可加速备份(需 PostgreSQL 12+)

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

相关文章

  • postgreSQL如何设置数据库执行超时时间

    postgreSQL如何设置数据库执行超时时间

    本文我们将深入探讨PostgreSQL数据库中的一个关键设置SET statement_timeout,这个设置对于管理数据库性能和优化查询执行时间非常重要,让我们一起来了解它的工作原理以及如何有效地使用它
    2024-01-01
  • 详解PostgreSQL 14.4安装使用及一些安装的异常问题

    详解PostgreSQL 14.4安装使用及一些安装的异常问题

    这篇文章主要介绍了PostgreSQL 14.4的安装以及使用以及一些安装的异常,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-07-07
  • pgsql之pg_stat_replication的使用详解

    pgsql之pg_stat_replication的使用详解

    这篇文章主要介绍了pgsql之pg_stat_replication的使用详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • Postgresql数据库密码忘记的详细解决方法

    Postgresql数据库密码忘记的详细解决方法

    在使用PostgreSQL数据库时,忘记数据库密码可能会影响到正常的开发和维护工作,这篇文章主要介绍了Postgresql数据库密码忘记的详细解决方法,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2025-06-06
  • PostgreSQL数据库字符串拼接、大小写转换以及substring详解

    PostgreSQL数据库字符串拼接、大小写转换以及substring详解

    在日常工作中会遇到将多行的值拼接为一个值展现,下面这篇文章主要给大家介绍了关于PostgreSQL数据库字符串拼接、大小写转换以及substring的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-04-04
  • 使用postgresql 模拟批量数据插入的案例

    使用postgresql 模拟批量数据插入的案例

    这篇文章主要介绍了使用postgresql 模拟批量数据插入的案例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • PostgreSQL中扩展moddatetime的使用

    PostgreSQL中扩展moddatetime的使用

    PostgreSQL的moddatetime扩展通过触发器自动维护时间戳字段,轻量高效,适用于审计日志和多租户系统,具有一定的参考价值,感兴趣的可以了解一下
    2025-06-06
  • postgreSQL数据库的监控及数据维护操作

    postgreSQL数据库的监控及数据维护操作

    这篇文章主要介绍了postgreSQL数据库的监控及数据维护操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • PostgreSQL对GROUP BY子句使用常量的特殊限制详解

    PostgreSQL对GROUP BY子句使用常量的特殊限制详解

    这篇文章主要介绍了PostgreSQL对GROUP BY子句使用常量的特殊限制详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-02-02
  • 浅谈postgresql数据库varchar、char、text的比较

    浅谈postgresql数据库varchar、char、text的比较

    这篇文章主要介绍了浅谈postgresql数据库varchar、char、text的比较,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-12-12

最新评论