git初始化后,我添加并提交了一些文件,做了一些修改,添加并提交。设置git守护进程(在WinXP上的Cygwin下运行)并克隆一次存储库。 现在,我得到这个错误与克隆的存储库:
$ git status
error: bad index file sha1 signature
fatal: index file corrupt
除了获得一个新的存储库副本之外,还有什么方法可以修复这个问题吗?
git初始化后,我添加并提交了一些文件,做了一些修改,添加并提交。设置git守护进程(在WinXP上的Cygwin下运行)并克隆一次存储库。 现在,我得到这个错误与克隆的存储库:
$ git status
error: bad index file sha1 signature
fatal: index file corrupt
除了获得一个新的存储库副本之外,还有什么方法可以修复这个问题吗?
当前回答
我做了一个简单的魔术。我克隆回购到一个新的文件夹。从新文件夹复制。git文件夹到repo的旧文件夹,替换。git。
其他回答
这听起来像是一个糟糕的克隆。你可以试试下面的方法来获取(可能吗?)更多信息:
git fsck --full
如果问题是索引作为提交的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文件夹。
你需要回到你的主回购。其中,删除。git/worktrees/<name_of_tree>/index
然后按照其他答案运行git reset。
我做了一个简单的魔术。我克隆回购到一个新的文件夹。从新文件夹复制。git文件夹到repo的旧文件夹,替换。git。