postgresql – 使用pg_dump只能使用compress参数进行备份损坏?
发布时间:2020-12-13 15:59:49 所属栏目:百科 来源:网络整理
导读:我使用此命令备份200GB数据库(postgres 9.1,win7 x64): pg_dump -Z 1 db_name backup 它创建了16GB的文件,我觉得很好,因为以前的备份工作(并且由ext工具打包)具有相似的大小.现在,当我尝试使用pg_restore恢复到PG9.2时,我收到错误: input file does not ap
我使用此命令备份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. 现在哪种格式的文件?它只是tar或gzip(winrar显示gzip)? 解决方法
你在“备份”中输出的只是压缩普通的sql.
你可以通过提示检查它: gzip -l backup 不幸的是,pg_retore没有提供恢复PLAIN SQL的可能性, 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上给你一个错误 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |