git pull时遇到error: cannot lock ref 'xxx': ref xxx is at (一个commitID) but expected的解决办法

在执行git pull时遇到如下错误:

error: cannot lock ref 'xxx': ref xxx is at (一个commitID) but expected

遇到这个错误会导致git pull失败。

问题原因

这个git工程的.git/refs目录下跟踪的某些git分支,在git pull的时候,与远端的对应分支的refs对比发现不同,所以导致git pull报错。
通常产生这个问题的原因是(以分支git/yousa/feature_01为例):

  1. 有人操作git/yousa/feature_01这个分支,在git push的时候使用了git push –force,(当然这个人的git push是push不上去),导致远端分支被覆盖,你本地的refs与远端无法一致,导致问题
  2. git分支是不区分大小写的,如果有人删除掉这个远端分支又重新新建了一个这个分支也会出现同样的问题。

解决办法

根据前面的原因有一些操作方法,基本思路就是要么,强行git pull;要么则是删除掉有问题的refs,再进行git pull(个人还是推荐第二种)(以分支git/yousa/feature_01为例)

  1. 删除有问题的refs,可以直接在.git/refs下面根据错误提示删除对应的refs文件,比如这个就是需要删除refs/remotes/origin/git/yousa/feature_01文件(嫌麻烦直接删除整个refs目录也行)
  2. 使用git命令删除相应refs文件,git update-ref -d refs/remotes/origin/git/yousa/feature_01
  3. 简单粗暴强行git pull,执行git pull -p
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 唉~我以为休息几天就不会痛了,看来我还是太天真了,实在是闲不住了,今天重新开始写笔记吧,读者们也注意身体,不要久坐...
    蜘蛛的梦呓阅读 3,297评论 0 0
  • Git 基础 基本原理 客户端并不是只提取最新版本的文件快照,而是把代码仓库完整的镜像下来。这样一来,任何一处协同...
    __silhouette阅读 16,055评论 5 147
  • "震惊!山东某高校校区学生集体出逃,甚至外出开房,原因竟是这..." 原因是,我们校区停电了,还停了两天。所以这个...
    安歌北浔阅读 1,683评论 0 0
  • AMicroera阅读 2,622评论 0 1
  • 昨天刚读了灰鸽的《一个故事告诉你记住好友号码有多么重要!》一文,被他诙谐幽默的文风逗乐。今天出门就遇上事儿了。不过...
    忍不住想笑阅读 2,844评论 0 0