您的位置:首页 > 其它

git踩过的坑--电脑重启导致git文件破损

2019-05-25 17:34 2679 查看
今天中午下班的最后一秒,我push了我的代码,ding~电脑挂机了。我还暗暗庆幸还好提交好了代码。
下午修改了代码,想要更新线上时,git竟然挂了!我对git的使用真的还不算熟悉,遇到这种情况我真的那一瞬间就只有一脸懵,然后面向百度。
报错1:
error: bad signature
fatal: index file corrupt
原因:
由于index file在 git 里面一般指的是 .git/index 这个文件。这个文件保存的是暂存区的信息(索引信息)。可以通过 git ls-files --stage 来查看暂存区的内容。这个文件很重要!但是现在报 index file corrupt,说明这个文件已经损坏了。还好,我们有办法重新来生成这个文件:git read-tree 或者直接 git reset.
解决方法:
1.删除或重命名 .git/index 文件: rm -f .git/index
2. git reset

解决了第一个问题,我以为就好了,激动地再次操作,git status出现的文件全是绿色,我以为是全部要重新提交下呢,没当回事,直到我git commit时遇到了fatal,走不下去了,再次面向百度。
报错2:
fatal: cannot lock ref 'HEAD': unable to resolve reference 'refs/heads/master': reference broken
原因:
可能是push时电脑重启,导致git文件受损。
解决方法:
这个方法我是借鉴的别人的:远程重新check out这个工程到新的文件夹,把新项目的 .git文件夹完整复制到 出错的文件夹中,然后再commit,push。

但是我没有借鉴的那位博主幸运,接下来我的代码就......冲突了,最不想遇到的就是冲突。
报错3:
Automatic merge failed; fix conflicts and then commit the result
解决方法:
emmm,可以下载一个Visual Studio Code来解决冲突。

解决完冲突之后,add,commit,pull,push,成功结束了这次的‘惨剧’。如果有更好的办法,希望大家多多指教!


                                            
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  Git