Git Merge 、Rebase
大约 4 分钟
Git Merge 、Rebase
git merge a
会找到两个分支的共同祖先、以及两个分支各自最新的提交,然后进行三方合并,并且在对合并中修改的内容形成一个新的commit
git rebase a
也就是变基,即把当前分支的祖先更改为a分支最新的提交。此时a为基分支,当前分支为**待变基分支。**git会从两个分支的祖先开始提取待变基分支的提交,然后把当前分支指针指向基分支最新提交,然后应用刚才提取到的修改(即:以a为基底合并当前分支代码)
rebase与merge的功能都是合并代码
现在假设有两个分支:dev 和 dev-pqs (dev-pqs是模拟各个开发人员的开发分支)
dev-pqs基于dev分支拉出,然后进行了 A B两个提交
然后dev分支分支有个新的提交 M(比如是其他开发人员合并上去的),如下图
把dev-pqs的代码合并到dev
merge
- 切换当前分支为dev-pqs
- 执行git merge dev (后续应该再切换到dev分支,然后把dev-pqs合并到dev,这个步骤就省略了,因为如果有冲突,冲突已经在1、2两个步骤解决掉了,也可以直接执行这两个步骤)
结果如下:
rebase
- 切换当前分支为 dev-pqs
- 执行 git rebase dev (后续应该再切换到dev分支,然后把dev-pqs合并到dev,这个步骤就省略了,因为如果有冲突,冲突已经在1、2两个步骤解决掉了,也可以直接执行这两个步骤)
rebase前,dev-pqs分支的祖先是dev那个提交,rebase后,祖先就更改为dev的最新提交,也就是m那次提交。如下图:
区别
- merge操作通常会生成一个新的commit,已提交的commit的版本号不会发生编号
- merge后分支的祖先信息不会丢失
- merge操作后的结果能提现出时间线
- rebase操作后分支祖先信息会丢失,如上图看不出dev-pqs的祖先
- rebase同时会更改commit的版本号,比如上面的A、B两个提交的版本号就发生了变化。A: 11e75—>c78c B: 68b0—>106d
- rebase操作后并不是按照时间线排列(当然可以根据提交时间判断)
merge还是rebase?
根据上面的区别,再根据公司、项目实际情况选择使用即可
git pull
git pull 等效于 git fetch + git merge
git pull -r 等效于 git pull -rebase 又等效于 git fetch + git rebase
idea的rebase操作
点击红框”rebase dev-pqs onto dev” 就相当于在执行 git rebase dev,一样的效果。 这个”onto”感觉很形象,有点体现出以dev为基底的感觉
idea设置
系统推荐
- Notion笔记定时备份
- KVM 虚拟机安装
- ES6.2.3(3节点)数据迁移到ES7.4.1(5节点)
- 乱七八糟的笔记
- 线上FullGC频繁的排查
- 批量修改git历史记录中的用户名和邮箱
- Docker笔记
- MySQL三大日志
- MySQL数据迁移到PGSQL
- Docker隐射的端口外网不能访问
- Docker跨主机通信方案
- sofajraft
- 随机毒鸡汤:头这么疼,一定是有人在压榨我的智慧。