今天中午下班的最后一秒,我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,成功结束了此次的‘惨剧’。若是有更好的办法,但愿你们多多指教!