pg_dumpall [ option...]
pg_dumpall 是一个用于写出("转储")一个数据库集群里的所有 PostgreSQL 数据库到一个脚本文件的工具。 该脚本文件包含可以用于作为 psql(1) 的输入恢复数据库的SQL命令。 它通过对数据库集群里的每个数据库调用 pg_dump(1) 实现这个功能。 pg_dumpall 还转储出所有数据库公用的全局对象。 (pg_dump(1) 并不保存这些对象。) 这些信息目前包括数据库用户和组,以及适用于整个数据库的访问权限。
因此,pg_dumpall 是备份你的数据库的一体化解决方案。 但是请注意它的局限性:它无法转储"大对象",因为 pg_dump 无法把这样的对象转储到纯文本文件中。如果你的数据库里有大对象, 那么你应该使用 pg_dump 的非文本输出格式之一转储它们。
因为 pg_dumpall 从所有数据库中读取表, 所以你很可能需要以数据库超级用户的身份联接,这样才能生成完整的转储。 同样,你也需要超级用户的权限执行保存下来的脚本,这些才能增加用户和组, 以及创建数据库。
SQL脚本将写出到标准输出。你应该使用合适的 shell 操作符把它重定向到文件。
pg_dumpall 需要和 PostgreSQL 服务器连接多次,可能每次都问你口令。这种情况下写一个 $HOME/.pgpass 可能会比较方便。
下列命令行参数用于控制输出格式:
pg_dumpall 可以处理来自以前版本的 PostgreSQL 的数据库,但是太老的数据库就不再支持了(目前到 7.0)。 如果你需要覆盖版本检查,那么可以使用这个选项(如果 pg_dumpall 失败了,可别说我们没警告你。)
下面的命令行参数控制数据库连接参数。
因为 pg_dumpall 内部调用 pg_dump,所以,一些诊断信息 可以参考 pg_dump。
恢复完之后,我们建议在每个已恢复的对象上运行 ANALYZE。 这样优化器就可以得到有用的统计。 你也可以用 vacuumdb -a -z 清理所有数据库。
转储所有数据库:
$ pg_dumpall > db.out
重新载入这个数据库:
$ psql -f db.out template1
(在这里你和哪个数据库联接并不重要,因为 pg_dumpall 创建的脚本文件将包含合适的命令用于创建和联接保存的数据库。)
pg_dumpall - 抽出一个 PostgreSQL 数据库集群到脚本文件中
原文:https://www.cnblogs.com/fanweisheng/p/11097456.html