本文主要是介绍git“fatal: loose object”错误解决办法汇总,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
描述
不知道怎么回事,最近连续出现了两三次下面的错误,每次Git pull
的时候就会出现,网络搜索了一下,类似的问题非常普遍,各有各的解决之道,随记之。
错误信息:
error: object file .git/objects/40/bda4e3b79c3d7bf598df31d9e68470f97a3f79 is empty
fatal: loose object 40bda4e3b79c3d7bf598df31d9e68470f97a3f79 (stored in .git/objects/40/bda4e3b79c3d7bf598df31d9e68470f97a3f79) is corrupt
- 1
- 2
- 1
- 2
解决办法
这里的解决办法,主要针对存在未提交的代码的情况。下面的命令,全部在ubuntu下使用,win下要主要命令的不同。
(1)重新克隆法
这个在stackoverflow.com上,大家点赞的比较多。
注意事项:该方法会丢失你的本地未push的提交和改变,也会丢失所有stash,处理之后需要重新提交。foo为本地版本库。
cp -R foo foo-backup
git clone git@www.mydomain.de:foo foo-newclone
rm -rf foo/.git
mv foo-newclone/.git foo
rm -rf foo-newclone
- 1
- 2
- 3
- 4
- 5
- 1
- 2
- 3
- 4
- 5
(2)reflog法(未验证)
这种方法暂时没有尝试,希望能用。
rm .git/objects/40/bda4e3b79c3d7bf598df31d9e68470f97a3f79
git fsck --full
git reflog
- 1
- 2
- 3
- 1
- 2
- 3
(3)fetch法 (未验证)
特别注意:这个与上面第一种方法比较类似,但是国内的文档大多少了一步备份本地版本库,导致自己的未push的工作丢失。
cp -R foo foo-backup //备份先
rm -fr .git
git init
git remote add origin [your-git-remote-url]
git fetch
git reset --mixed origin/master //国内文档大多把这里改成了--hard,未提交彻底丢失
git branch --set-upstream-to=origin/master master
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 1
- 2
- 3
- 4
- 5
- 6
- 7
参考
http://stackoverflow.com/questions/4254389/git-corrupt-loose-object/13918515#13918515
http://862123204-qq-com.iteye.com/blog/1683315
这篇关于git“fatal: loose object”错误解决办法汇总的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!