概述

一直以来对git的rebase和merge命令都有点混淆,刚好有朋友问到这一块,所以也抽空去整理了下这方面内容,以作备忘!


merge和rebase

git的merge和rebase都是用来合并分支的。

这里不多解释rebase命令,以及两个命令的原理,下面主要说的是两者在实际操作中的区别。

git merge与rebase 使用场景(详解git在工作中的merge和rebase功能及区别)(1)


什么是分支

分支就是便于多人在同一项目中的协作开发。比方说:每个人开发不同的功能,在各自的分支开发过程中互不影响,完成后都提交到develop分支。极大的提高了开发的效率。


合并分支

每个人创建一个分支进行开发,当开发完成,需要合并到develop分支的时候,就需要用到合并的命令。


什么是冲突

合并的时候,有可能会产生冲突。

冲突的产生是因为在合并的时候,不同分支修改了相同的位置。所以在合并的时候git不知道那个到底是你想保留的,所以就提出疑问(冲突提醒)让你自己手动选择想要保留的内容,从而解决冲突。


merge和rebase的区别

1、采用merge和rebase后,git log的区别,merge命令不会保留merge的分支的commit

git merge与rebase 使用场景(详解git在工作中的merge和rebase功能及区别)(2)

2、处理冲突的方式:

3、git pull和git pull --rebase区别

git pull做了两个操作分别是‘获取’和合并。所以加了rebase就是以rebase的方式进行合并分支,默认为merge。


git merge 和 git merge --no-ff的区别

1、只有在冲突的时候,解决完冲突才会自动产生一个commit。

如果想在没有冲突的情况下也自动生成一个commit,记录此次合并就可以用:git merge --no-ff命令,下面用一张图来表示两者的区别:

git merge与rebase 使用场景(详解git在工作中的merge和rebase功能及区别)(3)

2、如果不加 --no-ff 则被合并的分支之前的commit都会被抹去,只会保留一个解决冲突后的 merge commit。


如何选择合并分支的方式

我的理解:主要是看那个命令用的熟练,能够有效的管理自己的代码;还有就是团队用的是那种方式。

我对于rebase比较熟悉,所以我一般都用rebase,但是现在的公司用的是merge --no-ff命令合并分支。所以,我在工作上就用merge,个人项目就用rebase。

也可以两者结合:


总结

其实看懂上面的两幅图就行了。注意两点:commit log的区别和处理冲突的方式。

后面会分享更多devops和DBA方面的内容,感兴趣的朋友可以关注一下~

git merge与rebase 使用场景(详解git在工作中的merge和rebase功能及区别)(4)

,