【Git/SVN】error: failed to push some refs to ... (non-fast-forward) 终极解决方案!

必经之路

如果你是个git新手,通过网上那一页教程学会了使用git bash将自己的项目push到远端repository。那么你一定遇到过如下的问题:
在这里插入图片描述

error: failed to push some refs to ‘ur repository’

必踩の坑

而如果,你百度了这个问题,你将在百度的前三页搜索中得到完全相同的答案:

问题(non-fast-forward)的出现原因在于:
git仓库中已经有一部分代码,所以它不允许你直接把你的代码覆盖上去。于是你有2个选择方式:
1,强推,即利用强覆盖方式用你本地的代码替代git仓库内的内容
$ git push -f
2,先把git的东西fetch到你本地然后merge后再push
$ git fetch
$ git merge

以上皆为狗屁

如果你真的照做了:

  • 第一个方法会完全覆盖掉你之前的提交。如果你只是提交几个修改,那就真是得不偿失了。
  • 第二个方法并没什么卵用。
终极解决方案

出现(non-fast-forward)的根本原因是repository已经存在项目且不是你本人提交(我知道是大概率你提交的,但是git只认地址),你commit的项目和远程repo不一样。这时该怎么办呢?很简单,把远端项目拉回本地:

$ git pull

然而pull回来之后,你再push依旧会fail。
原因是他们是两个不同的项目,要把两个不同的项目合并,不能简单的 git pull。而是

$ git pull origin master --allow-unrelated-histories

这条命令允许了不同项目的合并。
好了,pull成功了。
接下来

$ git push origin master

游戏结束over~

感谢

如果解决了你棘手的问题的话,给个赞哈,谢谢~

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值