Loading

git 报错 error: failed to push some refs to .....

  git push 代码的时候报错,报错如下:

  

  这种报错是因为远程仓库的代码和本地仓库的代码不同步,对本地的代码进行一次拉取,再 git push 就可以解决了

 

  通过如下命令进行代码合并

git pull --rebase origin master

   或

git pull origin master

  

  git pull 拉取之后就可以 git push 代码;  

 

  • git pull 与 git pull --rebase 的区别
   git pull = git fetch + git merge FETCH_HEAD
   git pull --rebase = git fetch + git rebase FETCH_HEAD

   merge 操作会生成一个新的节点,之前的提交分开显示;而 rebase 操作不会生成新的节点,该命令是将两个分支融合成一个线性的提交,操作完成后会将相对于rebase过来的分支后面的commit id更改,又称变基;

  

   有两个分支,如下图:

       D---E (dev)
      /
 A---B---C---F (master)

 

   在 master 执行 git merge dev,然后会得到如下结果:

      D--------E
      /          \
 A---B---C---F----G   (dev, master)

 

   在 master 执行 git rebase dev,然后得到如下结果:

A---B---D---E---C‘---F‘  (dev, master)

  将master分支相对于dev分支后面新增的两次提交的commit id变更,rebase命令适合用在本地,远程慎用;

 

  参考如下:

  https://stackoverflow.com/questions/30471557/git-push-master-fatal-you-are-not-currently-on-a-branch

 

posted @ 2019-11-22 10:31  街头卖艺的肖邦  阅读(303)  评论(0)    收藏  举报