PostgreSQL 备份与恢复

备份

备份数据库,需要使用pg_dump指令,它将指定的数据库所有内容转储到一个文件中,在数据库服务器上运行入下指令

$ pg_dump -U db_user -W -F t db_name > /path/to/your/file/dump_name.tar
# -U 指定哪个用户将连接到数据库服务器
# -W 强制pg_dump在连接到服务器之前提示输入密码
# -F 用于指定输出文件的格式,可以是以下之一:
#       p - 纯文本SQL脚本
#       c - 自定义格式存档
#       d - 目录格式存档
#       t - tar格式存档

pdtar格式适合使用pg_restore进行恢复

恢复

数据库的恢复操作有如下两种

psql

pg_dump创建出来的纯SQL文件中进行恢复

$ psql -U db_user db_name < dump_name.pgsql

db_user数据库用户,db_name是数据库名称,dump_name.sql是备份文件的名称

pg_restore

pg_dump创建出来的.tar文件,目录或使用的自定义格式进行恢复

$ pg_restore -d db_name /path/to/your/file/dump_name.tar -c -U db_user
# 各种选项,例如:
# -c 在重新创建数据库对象之前删除它们
# -C 在恢复之前创建数据库
# -e 如果遇到错误则退出
# -F format指定存档的格式

示例

  • 备份和还原单个数据库

备份

$ pg_dump -U postgres -d mydb > mydb.pgsql

还原

$ psql -U postgres -d mydb < mydb.pgsql
  • 备份和还原所有数据库

备份

$ pg_dumpall -U postgres > alldbs.pgsql

还原

$ psql -U postgres < alldbs.pgsql
  • 备份和恢复单表

备份

$ pg_dump -U postgres -d mydb -t mytable > mydb-mytable.pgsql

还原

$ psql -U postgres -d mydb < mydb-mytable.pgsql
  • 压缩备份和还原数据库

备份

$ pg_dump -U postgres -d mydb | gzip > mydb.pgsql.gz

从压缩备份文件直接恢复

$ gunzip -c mydb.pgsql.gz | psql -U postgres -d mydb
  • 一个简单的备份脚本
file_name="db-`date +%F-%H-%M-%S`.sql"
export PGPASSWORD="xxxxxxxxxx"

pg_dump -h 127.0.0.1 -U db -w -F p db > ~/.backup/$file_name

相关说明:

1、VIP会员无限制任意下载,免积分。立即前往开通>>

2、下载积分可通过日常 签到绑定邮箱 以及 积分兑换 等途径获得!

3、本站资源大多存储在云盘,如出现链接失效请评论反馈,如有密码,均为:www.ipipn.com。

4、所有站内资源仅供学习交流使用。未经原版权作者许可,禁止用于任何商业环境,否则后果自负。为尊重作者版权,请购买正版作品。

5、站内资源来源于网络公开发表文件或网友分享,如侵犯您的权益,请联系管理员处理。

6、本站提供的源码、模板、软件工具等其他资源,都不包含技术服务,请大家谅解!

7、源码、模板等资源会随着技术、坏境的升级而存在部分问题,还请慎重选择。

PS.源码均收集自网络,如有侵犯阁下权益,请发信件至: admin@ipipn.com .


源站网 » PostgreSQL 备份与恢复

发表评论

赞助本站发展 维持服务器消耗

全站源码免费下载 立刻赞助