git初始化后,我添加并提交了一些文件,做了一些修改,添加并提交。设置git守护进程(在WinXP上的Cygwin下运行)并克隆一次存储库。 现在,我得到这个错误与克隆的存储库:

$ git status
error: bad index file sha1 signature
fatal: index file corrupt

除了获得一个新的存储库副本之外,还有什么方法可以修复这个问题吗?


当前回答

在Windows PowerShell上,应该是这样

rm -Force .git/index
git reset

其他回答

当其中一个子目录下有一个.git目录时,就会出现此问题。要修复此问题,请检查是否有其他.git目录,并删除它们并重试。

如果问题是索引作为提交的staging区域(即.git/index),你可以简单地删除索引(如果你想要备份副本),然后将索引恢复到上次提交的版本:

在OSX/Linux/Windows(与Git bash):

rm -f .git/index
git reset

在Windows上(使用CMD而不是git bash):

del .git\index
git reset

(上面的reset命令与git reset——mixed HEAD相同)

你也可以使用底层的git读树来代替git重置。


如果问题出在packfile的索引上,你可以使用git index-pack来恢复它。

由于上述解决方案给我带来了持续的问题,我使用了这个乏味的解决方案:

在其他地方克隆一个新的副本 将新的.git目录复制到包含我想提交的更改的(损坏的)repo中

成功了。顺便说一句,我做了一个sed项目根@hobs猜测。我吸取教训了。

我有同样的错误,并试图修复它所描述的接受的答案。然而,在重新设置.git/index中的索引后,它再次被损坏。

问题是,我昨天正在使用git bisect来查找一个bug,但忘记在一天结束时运行git bisect reset来清理。今天,当我开始进行更改时,git感到困惑,因为它仍然处于平分模式,而我正试图应用更改。我也不能只是运行git bisect reset,因为已经有变化了。

要解决这个问题,在根目录下的git bash中执行以下命令:

git stash -m <message>
git bisect reset        # You are now most likely in detached head mode
git checkout <branch>
git stash apply         # If you have multiple stashes, make sure 
                          to apply the correct one

注意,在这种情况下,不需要删除.git/index并重置索引!

rm -f .git/index
git reset

更多信息请访问https://www.chris-shaw.com/blog/quick-fix-for-git-corrupt-index