昨天晚上我在写一个提交消息时遇到了电源故障。当我启动机器备份时,我无法完成提交。我跑了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是电力故障前最后一次成功提交。
答案 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对象。
比逐一跟踪它们快得多!