微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

postgresql – 使用pg_dump只能使用compress参数进行备份损坏?

我使用此命令备份200GB数据库(postgres 9.1,win7 x64):

pg_dump -Z 1 db_name > backup

它创建了16GB的文件,我觉得很好,因为以前的备份工作(并且由ext工具打包)具有相似的大小.现在,当我尝试使用pg_restore恢复到PG9.2时,我收到错误

input file does not appear to be a valid archive

使用pg_restore -Ft:

[tar archiver] corrupt tar header found in ▼ (expected 13500752,com
puted 78268) file position 512

Gzip也表明它已经损坏了.当我在Total Commander中打开备份文件时,内部文件只有1.8GB.
当我在寻找解决方案时,可能应该使用-Cf参数进行转储.

现在哪种格式的文件?它只是tar或gzip(winrar显示gzip)?
有没有办法正确地恢复它或者它以某种方式被破坏(转储时没有错误)?可能是由于tar或gzip的文件大小限制?

解决方法

你在“备份”中输出的只是压缩普通的sql.
你可以通过提示检查它:

gzip -l backup

不幸的是,pg_retore没有提供恢复PLAIN sql的可能性,
所以你只需要解压缩文件并使用psql -f< FILE>命令:

zcat backup > backup.sql
psql -f backup.sql

根据“Frank Heikens”提出的postgres 9.1,不可能使用pg_dump -Fc进行转储,因为转储格式在主要版本之间不兼容,例如9.0 – > 9.1 – > 9.2并且“pg_restore”会在9.2上给你一个错误

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐