1. 问题场景
最近工作机从Windows换成了Mac, 发现在Mac 机上pull代码时总会出现“fatal: Not possible to fast-forward, aborting”,然而在Windows机是没有问题的。
开发流程:基于release拉取一个feature分支,然后在feature分支上进行开发,再把feature分支往master合并,如果有冲突先git pull 一下,然后解决冲突进行push。 (release是master的子集)
上述流程在windows上运行很流畅但是到mac上就不行,在stackoverflow的大佬说是因为base不一致,需要使用rebase去解决,百度上也是这么描述的。虽然这种方式帮助很多人解决了问题,但绝不是我所想要的解决方式。因为我想使用git pull后即使有冲突而不是以这样的方式显示。
2.问题解决
合并代码的方式有很多中:git merge,git rebase,git pull等
git 在处理文件merge时,会分成三种处理方式
- –ff–only fast forward模式,快速合并 有冲突就会失败
- –no–ff 非快速合并 会生成一次commit
- –squash 将合并后的不同分支所有的提交记录作为一次提交
fase-forward只要存在冲突就会失败, 我们得配置git pull
- git config pull.rebase false