git rebase后不能push问题

 

解决办法

1、feature分支只有你一个人在开发

此时没有其他人会进行提交操作,那么可以直接进行强制推送 git push --force origin feature ,–force可以直接理解为用你本地分支的状态区覆盖掉远端origin分支的状态,也就是执行过后,本地的分支什么样,远端分支就什么样


2、feature分支有多人开发

此时如果你贸然的使用–force命令,会有覆盖掉其他人提交代码的风险。比如,小明和小红两个人同时在feature分支上进行开发,小明已经在feature分支上提交了一部分代码,而小红此时执行了rebase操作,所以如果想要推送到远端仓库就必须使用 - -force 参数,而小红推送成功之后就会覆盖掉小明提交的代码(前面说过–force就是用本地状态覆盖掉远端状态)。在这种情况下,推荐另外一种更安全的命令  git push --force-with-lease origin feature  使用该命令在强制覆盖前会进行一次检查如果其他人在该分支上有提交会有一个警告,此时可以避免福改代码的风险。

 


 

 

Ref:

https://blog.csdn.net/StephenGuoYang/article/details/84915417

https://www.cnblogs.com/xinmengwuheng/p/11301657.htmlone   --- very good

上一篇:史上最全git命令集


下一篇:一些比较常用的git命令