前提:如果要备份 A 库并恢复数据到 B 库,需要版本号一致。例如一个 PG14 备份文件恢复到 PG11 上就会提示错误。
-
备份命令
pg_dump -U postgres -h 192.168.1.10 -p 5432 -d test_db -f backup.tar -F tar -OW
# 排除指定的表,并且显示详细过程日志 pg_dump -U postgres -h 192.168.1.10 -p 5432 -d test_db -f backup.tar -F tar -OW -T t_test -v
参数 说明 -U 用户名 -h pg hostname -p pg port -d 要备份的数据库名 -f 指定备份文件名称和路径 -F 选择输出的格式 -O 让该脚本可以被任何用户恢复并且将脚本中对象的所有权赋予该选项指定的用户 -W 强制 pg_dump 在连接到数据库之前提示一个密码 -T 排除指定的表,可以多次使用以排除多个表 -v 显示备份过程中的详细日志信息 参考链接: pg_dump 命令大全
- 恢复命令
其中参数说明参考上文链接。pg_restore -U postgres -h 192.168.1.11 -p 5432 -d test_db -O -x -v < backup.tar