error: cannot lock ref ‘xxx’: ref xxx is at (一个commitID) but expected的解决办法
原因:原因是你这个git工程的.git/refs目录下跟踪的某些git分支,在git pull的时候,与远端的对应分支的refs对比发现不同,所以导致git pull报错。
通常产生这个问题的原因是(以分支git/yousa/feature_01为例):
有人操作git/yousa/feature_01这个分支,在git push的时候使用了git push –force,(当然这个人的git push是push不上去),导致远端分支被覆盖,你本地的refs与远端无法一致,导致问题
git分支是不区分大小写的,如果有人删除掉这个远端分支又重新新建了一个这个分支也会出现同样的问题。
解决方法:
删除有问题的refs,可以直接在.git/refs下面根据错误提示删除对应的refs文件,比如这个就是需要删除refs/remotes/origin/git/yousa/feature_01文件(嫌麻烦直接删除整个refs目录也行)
使用git命令删除相应refs文件,git update-ref -d refs/remotes/origin/git/yousa/feature_01
简单粗暴强行git pull,执行git pull -p
网友评论