如何恢复因硬盘故障而损坏的Git对象?
我遇到了硬盘故障导致Git存储库的某些文件损坏。运行时,git fsck --full我得到以下输出:
error: .git/objects/pack/pack-6863e0a0e4b4ded6090fac5d12eba6ca7346b19c.pack SHA1 checksum mismatch
error: index CRC mismatch for object 6c8cae4994b5ec7891ccb1527d30634997a978ee from .git/objects/pack/pack-6863e0a0e4b4ded6090fac5d12eba6ca7346b19c.pack at offset 97824129
error: inflate: data stream error (invalid code lengths set)
error: cannot unpack 6c8cae4994b5ec7891ccb1527d30634997a978ee from .git/objects/pack/pack-6863e0a0e4b4ded6090fac5d12eba6ca7346b19c.pack at offset 97824129
error: inflate: data stream error (invalid stored block lengths)
error: failed to read object 0dcf6723cc69cc7f91d4a7432d0f1a1f05e77eaa at offset 276988017 from .git/objects/pack/pack-6863e0a0e4b4ded6090fac5d12eba6ca7346b19c.pack
fatal: object 0dcf6723cc69cc7f91d4a7432d0f1a1f05e77eaa is corrupted
我有存储库的备份,但包含包文件的唯一备份已经损坏了。所以我认为我必须找到一种方法从不同的备份中检索单个对象,并以某种方式指示Git生成一个只有正确对象的新包。
你能否告诉我如何修复我的存储库?
查看完整描述
TA贡献1693条经验 获得超4个赞
在以前的一些备份中,您的坏对象可能已经打包在不同的文件中,或者可能是松散的对象。所以你的对象可能会被恢复。
看来你的数据库中有一些坏对象。所以你可以用手动的方式做到这一点。
因为
git hash-object
,
git mktree
并且
git commit-tree
因为它们在包中发现不写的对象,然后开始做这样的:
mv .git/objects/pack/* <somewhere>for i in <somewhere>/*.pack; do
git unpack-objects -r < $idonerm <somewhere>/*
(您的包将从存储库中移出,并再次在其中解压缩;只有好的对象现在在数据库中)
你可以做:
git cat-file -t 6c8cae4994b5ec7891ccb1527d30634997a978ee
并检查对象的类型。
如果类型是blob:从以前的备份中检索文件的内容(使用
git show
或
git cat-file
或
git unpack-file
;然后您可以
git hash-object -w
重写当前存储库中的对象。
如果类型是树:您可以使用
git ls-tree
从以前的备份恢复树; 然后
git mktree
在当前的存储库中再次编写它。
如果类型是commit:与
git show
,相同,
git cat-file
和
git commit-tree
。
当然,在开始此过程之前,我会备份您的原始工作副本。
另外,请看一下
如何恢复损坏的Blob对象
。
查看完整回答