Git存储库损坏(不正确的标头检查;松散的对象已损坏)

时间:2014-05-18 19:22:29

标签: git corrupt

昨天晚上我在写一个提交消息时遇到了电源故障。当我启动机器备份时,我无法完成提交。我跑了git reset,添加了已更改的文件,然后再次尝试,并得到了这个:

% git commit
error: inflate: data stream error (incorrect header check)
error: unable to unpack a94406345ac44982b00cf57b4b9660a35436637f header
fatal: a94406345ac44982b00cf57b4b9660a35436637f is not a valid object

git fsck显示以下内容:

% git fsck --full
Checking object directories: 100% (256/256), done.
error: inflate: data stream error (incorrect header check)
error: unable to unpack 4346883490a0990e68db0187241abc1642765a73 header
error: inflate: data stream error (incorrect header check)
fatal: loose object 4346883490a0990e68db0187241abc1642765a73 (stored in .git/objects/43/46883490a0990e68db0187241abc1642765a73) is corrupt

我注意到消息抱怨不同的对象。

我搜索了SO和网络并尝试了一些不同的东西,但无济于事。

  • 我没有最近的备份副本。
  • 将存储库克隆到另一个目录中没有帮助;新的存储库展示了完全相同的问题。
  • git stash提供与git commit相同的消息。所有其他git命令似乎都能正常工作。

如何判断错误并修复?

修改: git log按照建议输出(只是前几行):

% git log --oneline --decorate --all |head -n 8
253b086 (HEAD, new_tokenize) Normalized tokenizer interface slightly
0f2425a (master) Added procs to eval layer
a4d4c22 Added procedures as a type
d1e15ad (tag: v0.10) Added `if' form with tail call semantics
f94a992 (tag: v0.9) Completed environments
031116e Fixed bug where # on a line by itself caused segfault
3d8b09f Added environments, define and set!
01cc624 Put symbol table implementation into types.c

这是一个小型的个人项目;我通常只是在(主)工作,但我当时正在做一个实验(new_tokenize)。 253b086是电力故障前最后一次成功提交。

3 个答案:

答案 0 :(得分:63)

似乎git在.git / objects中为新提交创建了文件,但没有成功写入它们。我通过一次删除它们并重新运行git fsck --full以找到下一个来解决它。我从最初由git fsck报告的那个开始:

% rm -f .git/objects/43/46883490a0990e68db0187241abc1642765a73
% git fsck --full
Checking object directories: 100% (256/256), done.
error: inflate: data stream error (incorrect header check)
error: unable to unpack 86e7247af5865e857a3b61eed99986e2d9538df1 header
error: inflate: data stream error (incorrect header check)
fatal: loose object 86e7247af5865e857a3b61eed99986e2d9538df1 (stored in .git/objects/86/e7247af5865e857a3b61eed99986e2d9538df1) is corrupt
% rm -f .git/objects/86/e7247af5865e857a3b61eed99986e2d9538df1
% git fsck --full
Checking object directories: 100% (256/256), done.
error: inflate: data stream error (incorrect header check)
error: unable to unpack a94406345ac44982b00cf57b4b9660a35436637f header
error: inflate: data stream error (incorrect header check)
fatal: loose object a94406345ac44982b00cf57b4b9660a35436637f (stored in .git/objects/a9/4406345ac44982b00cf57b4b9660a35436637f) is corrupt

等等。我在git fsck清除之前删除了五个对象,相应(我猜)对应于我尝试提交的五个文件。我想文件历史记录根本没有损坏。

顺便说一句,我想到了另一种似乎也有效的方法。 git clone复制了坏对象,但git push没有。备份后,我创建了一个新的空存储库(--bare,因为否则你无法推送到主服务器),然后取消暂停我的更改并将两个分支推送到新存储库。然后,只需再次检查它并从备份中恢复最新的更改。

如果有人关心这里的失败机制,仍然感兴趣。

答案 1 :(得分:8)

对于遇到此问题的任何人来说这个问题的简单答案:git clone命令是修复,如果有一个远程仓库然后将其克隆到本地文件夹(删除损坏的本地仓库后),万一你没有远程仓库然后尝试将损坏的repo推送到github,然后从那里克隆它,我认为损坏的对象不会被推,它将解决问题

答案 2 :(得分:5)

this answer所述,我跑了:

git reflog expire --expire-unreachable=now --all
git gc --prune=now

它删除了我所有悬空的blob和悬空提交,以及损坏的db对象。

比逐一跟踪它们快得多!