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,成功结束了这次的‘惨剧’。如果有更好的办法,希望大家多多指教!
相关文章推荐
- apicloud git-svn 地址冲突,导致代码管理功能不可用.这个问题是由 windows 系统自身DLL加载机制引起的.一般重启电脑即可解决
- 解决 linux 由于修改 /etc/inittab 文件,导致 设置开机启动级别为 6 (重启)
- 电脑突然死机导致远程git项目异常问题解决
- CPU损坏导致电脑不断地重启
- Eclipse :git解决同文件修改相同位置时导致的冲突。
- 使用FileUpload控件上传文件导致重启
- 电脑断电导致日志文件损坏或者只有mdf还原数据解决
- 从EXCEL 导入记录后,如何释放?否则另外打开一个EXCEL文件得重启电脑.
- 安装SQL Server 2000 提示文件挂起错误解决办法---不需重启电脑
- 电源导致电脑自动重启
- [虚拟机-系统重启]文件系统损坏导致虚拟机无法正常启动的问题及解决方法
- git误commit大文件导致不能push问题解决
- 解决"安装文件有挂起的文件,请重启电脑"的通用解决方法
- git在push时候同一台电脑不同用户使用导致SSH冲突
- 在Web.Config文件中使用configSource,避免动态修改web.config导致asp.net重启(另添加一个Config文件用于管理用户数据)
- git换行符导致的提交整个文件的解决方案
- AVI等视频文件点击导致桌面重启
- git 已经track 的文件再忽略导致不起作用
- 在Web.Config文件中使用configSource,避免动态修改web.config导致asp.net重启(另添加一个Config文件用于管理用户数据)