git rebase和merge的区别,rebase的运动过程和conflict的解决

广告位招租
扫码页面底部二维码联系

公司git管理中权限控制的比较严格,普通【版权所有】唐霜 www.tangshuang.net【作者:唐霜】成员仅有pull和push的权限,而且c著作权归作者所有,禁止商业用途转载。【原创内容,转载请注明出处】ommit的信息必须以jira的tick著作权归作者所有,禁止商业用途转载。著作权归作者所有,禁止商业用途转载。et号开头,没有merge的权限,一旦当转载请注明出处:www.tangshuang.net【版权所有】唐霜 www.tangshuang.net你push的commit中含有两个分支(著作权归作者所有,禁止商业用途转载。未经授权,禁止复制转载。two parents)的信息,就会提示【版权所有】唐霜 www.tangshuang.net【版权所有】唐霜 www.tangshuang.net错误。

【原创内容,转载请注明出处】本文作者:唐霜,转载请注明出处。著作权归作者所有,禁止商业用途转载。【访问 www.tangshuang.net 获取更多精彩内容】原创内容,盗版必究。

而在实际开发中,因为只有leader有在本文作者:唐霜,转载请注明出处。本文作者:唐霜,转载请注明出处。服务器上把其他分支merge进maste本文版权归作者所有,未经授权不得转载。【作者:唐霜】r的权限,所以leader每天都要rev【版权所有】唐霜 www.tangshuang.net【转载请注明来源】iew和merge来自不同开发者的不同分著作权归作者所有,禁止商业用途转载。【版权所有,侵权必究】支的代码。这里面自然就会导致一些conf原创内容,盗版必究。【版权所有,侵权必究】lict的,最简单的情况就是当两个pul转载请注明出处:www.tangshuang.net著作权归作者所有,禁止商业用途转载。l request发生的时候,第一个被m【关注微信公众号:wwwtangshuangnet】【版权所有,侵权必究】erge,可能在merge第二个时,就会【版权所有】唐霜 www.tangshuang.net【本文首发于唐霜的博客】产生conflict,无法merge。这【作者:唐霜】【版权所有】唐霜 www.tangshuang.net时leader一般会要求我们重新reba未经授权,禁止复制转载。未经授权,禁止复制转载。se一下代码,然后提交新的代码,以解决m【作者:唐霜】转载请注明出处:www.tangshuang.netaster merge第二个pull r【原创内容,转载请注明出处】原创内容,盗版必究。equest的conflict。

【本文首发于唐霜的博客】本文作者:唐霜,转载请注明出处。转载请注明出处:www.tangshuang.net【未经授权禁止转载】本文版权归作者所有,未经授权不得转载。

目标【本文首发于唐霜的博客】

本文版权归作者所有,未经授权不得转载。【原创不易,请尊重版权】本文版权归作者所有,未经授权不得转载。

我们的目标是将自己正在开发的分支reba本文版权归作者所有,未经授权不得转载。著作权归作者所有,禁止商业用途转载。se到develop最新的commit上【本文首发于唐霜的博客】著作权归作者所有,禁止商业用途转载。。从整个代码的提交关系,如图:
【关注微信公众号:wwwtangshuangnet】本文作者:唐霜,转载请注明出处。 git-rebase
【本文首发于唐霜的博客】本文版权归作者所有,未经授权不得转载。 这时,我们再push dev bran【转载请注明来源】原创内容,盗版必究。ch,master就能merge它了。

原创内容,盗版必究。【访问 www.tangshuang.net 获取更多精彩内容】著作权归作者所有,禁止商业用途转载。本文版权归作者所有,未经授权不得转载。

rebase和merge的区别【转载请注明来源】

著作权归作者所有,禁止商业用途转载。【本文首发于唐霜的博客】【作者:唐霜】【原创内容,转载请注明出处】【本文首发于唐霜的博客】

从上面的图中其实可以看出,rebase和【访问 www.tangshuang.net 获取更多精彩内容】【原创内容,转载请注明出处】merge是两个完全不一样的操作。但是由【访问 www.tangshuang.net 获取更多精彩内容】【本文首发于唐霜的博客】于它们过程中都会出现conflict的情本文版权归作者所有,未经授权不得转载。【转载请注明来源】况,所以容易搞模糊。

【作者:唐霜】【原创内容,转载请注明出处】著作权归作者所有,禁止商业用途转载。

rebase是将你当前的分支的起点(ba著作权归作者所有,禁止商业用途转载。未经授权,禁止复制转载。se)重新移到另一个节点。比如上图中,就本文版权归作者所有,未经授权不得转载。【关注微信公众号:wwwtangshuangnet】是讲dev分支的起点从master分支的原创内容,盗版必究。未经授权,禁止复制转载。a移到b。实际上,rebase可以在任何原创内容,盗版必究。【作者:唐霜】节点之间移来移去,只要你能解决好问题。

【版权所有】唐霜 www.tangshuang.net【未经授权禁止转载】本文作者:唐霜,转载请注明出处。本文作者:唐霜,转载请注明出处。【本文受版权保护】

merge则用debug分支来演示,de转载请注明出处:www.tangshuang.net【未经授权禁止转载】bug分支是从dev分支分出来的,但是它【本文首发于唐霜的博客】未经授权,禁止复制转载。的目的仅仅是为了解决bug,所以最后de【访问 www.tangshuang.net 获取更多精彩内容】本文版权归作者所有,未经授权不得转载。v把debug修改好的代码merge进来【版权所有】唐霜 www.tangshuang.net著作权归作者所有,禁止商业用途转载。

本文作者:唐霜,转载请注明出处。转载请注明出处:www.tangshuang.net【版权所有,侵权必究】【版权所有,侵权必究】【关注微信公众号:wwwtangshuangnet】

rebase和merge的区别如下:【版权所有】唐霜 www.tangshuang.net

【版权所有】唐霜 www.tangshuang.net【关注微信公众号:wwwtangshuangnet】【版权所有,侵权必究】
  1. merge是将另外一个分支merge进来【版权所有】唐霜 www.tangshuang.net本文作者:唐霜,转载请注明出处。,rebase是将自己rebase到另外【本文首发于唐霜的博客】转载请注明出处:www.tangshuang.net一个分支的另一个节点。也就是说所站在的分本文作者:唐霜,转载请注明出处。未经授权,禁止复制转载。支的视角不同,merge是一个向自己内部本文作者:唐霜,转载请注明出处。未经授权,禁止复制转载。的过程,rebase是对外的一个过程。
  2. 【关注微信公众号:wwwtangshuangnet】未经授权,禁止复制转载。【转载请注明来源】【访问 www.tangshuang.net 获取更多精彩内容】
  3. 被merge的分支其实可以结束了,可以被未经授权,禁止复制转载。【转载请注明来源】删掉,下次需要的时候再重新创建。reba未经授权,禁止复制转载。【未经授权禁止转载】se的分支并不结束,一般还会进行下一步操【原创内容,转载请注明出处】【版权所有】唐霜 www.tangshuang.net作。
  4. 【作者:唐霜】著作权归作者所有,禁止商业用途转载。原创内容,盗版必究。著作权归作者所有,禁止商业用途转载。
  5. rebase过程中涉及到merge操作,【未经授权禁止转载】【版权所有】唐霜 www.tangshuang.net所以,实际上所有的conflict都是m【未经授权禁止转载】本文版权归作者所有,未经授权不得转载。erge产生的。但是这里比较难理解,所以【版权所有】唐霜 www.tangshuang.net未经授权,禁止复制转载。要下文才能解释清楚。
  6. 本文作者:唐霜,转载请注明出处。本文版权归作者所有,未经授权不得转载。【转载请注明来源】【版权所有,侵权必究】

其实rebase跟merge是完全两个不本文版权归作者所有,未经授权不得转载。【版权所有】唐霜 www.tangshuang.net同的操作,只要狠狠抓住这点,理解上都会更【转载请注明来源】【原创内容,转载请注明出处】进一步。

【原创内容,转载请注明出处】转载请注明出处:www.tangshuang.net【版权所有】唐霜 www.tangshuang.net未经授权,禁止复制转载。

rebase的运动过程未经授权,禁止复制转载。

著作权归作者所有,禁止商业用途转载。【版权所有】唐霜 www.tangshuang.net转载请注明出处:www.tangshuang.net【版权所有】唐霜 www.tangshuang.net

从上面的图上看,感觉rebase挺简单的著作权归作者所有,禁止商业用途转载。【作者:唐霜】,就是把当前所在的分支的base改一下指原创内容,盗版必究。【本文首发于唐霜的博客】针就好了。但是实际上完全不是,rebas本文版权归作者所有,未经授权不得转载。本文版权归作者所有,未经授权不得转载。e是commit by commit的一【未经授权禁止转载】【原创不易,请尊重版权】个过程,跟我们想象的“改一下指针”完全不本文作者:唐霜,转载请注明出处。【原创不易,请尊重版权】同,可以说rebase的运动是最笨的一种本文版权归作者所有,未经授权不得转载。【转载请注明来源】运动。下面来解释上面我们给出的图中reb本文作者:唐霜,转载请注明出处。转载请注明出处:www.tangshuang.netase要实现的话都是怎样的一个过程。
【访问 www.tangshuang.net 获取更多精彩内容】【作者:唐霜】 git-rebase-workflow
【本文受版权保护】【原创不易,请尊重版权】 上图示意了rebase的运动过程,但是【未经授权禁止转载】本文作者:唐霜,转载请注明出处。别急,有地方需要阐述一下。上图的第一个、【本文首发于唐霜的博客】【访问 www.tangshuang.net 获取更多精彩内容】第二个状态说的是,当rebase发生的时【版权所有】唐霜 www.tangshuang.net【原创内容,转载请注明出处】候,首先实际上是把当前分支的所有comm转载请注明出处:www.tangshuang.net本文版权归作者所有,未经授权不得转载。it先捡出来,然后按照one by on【本文首发于唐霜的博客】【作者:唐霜】e的顺序进行暂时放置。

本文版权归作者所有,未经授权不得转载。【访问 www.tangshuang.net 获取更多精彩内容】【访问 www.tangshuang.net 获取更多精彩内容】【作者:唐霜】【原创不易,请尊重版权】

第三个状态是说,rebase实际上是以r【本文受版权保护】【关注微信公众号:wwwtangshuangnet】ebase的对象分支,也就是master原创内容,盗版必究。本文版权归作者所有,未经授权不得转载。分支指定的commit节点(默认是最新节著作权归作者所有,禁止商业用途转载。【版权所有】唐霜 www.tangshuang.net点)作为base,重新创建一个同名分支,【访问 www.tangshuang.net 获取更多精彩内容】【关注微信公众号:wwwtangshuangnet】也就是dev,这个时候,实际上老的dev【未经授权禁止转载】【本文首发于唐霜的博客】分支已经跟整个分支体系脱节了,只属于索引【未经授权禁止转载】【关注微信公众号:wwwtangshuangnet】结构中的暂存信息。新的dev分支其实相当原创内容,盗版必究。【版权所有】唐霜 www.tangshuang.netcheckout master && checkout -b dev,但是rebase并不会停在这个步骤,新原创内容,盗版必究。原创内容,盗版必究。的dev分支跟master是一模一样的。【转载请注明来源】【关注微信公众号:wwwtangshuangnet】接下来就是把老的dev分支上的commi【本文首发于唐霜的博客】【转载请注明来源】t一个一个转移到新的dev分支上。所以g【原创不易,请尊重版权】【本文首发于唐霜的博客】it从已经脱节的dev老分支中取出第一个【版权所有,侵权必究】未经授权,禁止复制转载。commit,并再次在新的dev分支上执【未经授权禁止转载】【本文首发于唐霜的博客】行commit的全套过程。

【原创不易,请尊重版权】【作者:唐霜】本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshuang.net

第四个状态和状态三种commit的过程是【原创不易,请尊重版权】【作者:唐霜】一样一样的,后面的所有commit都会按【版权所有,侵权必究】原创内容,盗版必究。照这个方式一个一个复制到新的dev分支中本文版权归作者所有,未经授权不得转载。【作者:唐霜】。注意,这里的“复制”不是改一下指针这么【原创内容,转载请注明出处】原创内容,盗版必究。简单,这里的复制其实是一个非常复杂的过程未经授权,禁止复制转载。【关注微信公众号:wwwtangshuangnet】,git从老的暂存的dev分支里面取出一【本文首发于唐霜的博客】著作权归作者所有,禁止商业用途转载。个commit之后,同时还要把代码的改动【版权所有,侵权必究】未经授权,禁止复制转载。也提交进来,这就会在上一个commit的【作者:唐霜】转载请注明出处:www.tangshuang.net基础上(上一个commit是指rebas【访问 www.tangshuang.net 获取更多精彩内容】【未经授权禁止转载】e过程中commit到新的dev分支)再原创内容,盗版必究。【转载请注明来源】次进行commit。如果不发生冲突,那么本文版权归作者所有,未经授权不得转载。著作权归作者所有,禁止商业用途转载。实际上这个过程是一个merge的过程,就原创内容,盗版必究。【作者:唐霜】是站在新的dev分支上,merge老的d【作者:唐霜】【本文首发于唐霜的博客】ev分支上对应的那个commit的改动,未经授权,禁止复制转载。本文作者:唐霜,转载请注明出处。同时还要把commit的信息也复制过来(【本文首发于唐霜的博客】【访问 www.tangshuang.net 获取更多精彩内容】而且这个commit信息也可以不复制,而【版权所有,侵权必究】未经授权,禁止复制转载。是自己重写过,具体可以参看这篇文章【版权所有,侵权必究】)。如此一个一个commit下去,直到把【本文首发于唐霜的博客】原创内容,盗版必究。所有的老的dev分支上的commit转移【关注微信公众号:wwwtangshuangnet】未经授权,禁止复制转载。到新的dev分支上。

【版权所有】唐霜 www.tangshuang.net【原创内容,转载请注明出处】本文版权归作者所有,未经授权不得转载。

当所有的commit复制完之后,新的de【版权所有】唐霜 www.tangshuang.net【访问 www.tangshuang.net 获取更多精彩内容】v分支其实是全新的一个分支,和老的dev【访问 www.tangshuang.net 获取更多精彩内容】【作者:唐霜】只是代码改动和commit上相同,但就g【版权所有,侵权必究】【访问 www.tangshuang.net 获取更多精彩内容】it的分支体系而言,是两个完全独立的,这【版权所有】唐霜 www.tangshuang.net著作权归作者所有,禁止商业用途转载。个时候从资源上看,老的dev分支应该还是【原创内容,转载请注明出处】著作权归作者所有,禁止商业用途转载。存在于git的索引中,直到整个rebas【未经授权禁止转载】本文版权归作者所有,未经授权不得转载。e完成之后,git自动将老的dev分支的【本文受版权保护】【访问 www.tangshuang.net 获取更多精彩内容】一切都清除。所以,当rebase完成之后,你无法恢复到re【访问 www.tangshuang.net 获取更多精彩内容】【转载请注明来源】base之前的状态,也就是第一张图片,你无法恢复到第一个状原创内容,盗版必究。著作权归作者所有,禁止商业用途转载。态。因此,rebase提供了abort功【转载请注明来源】著作权归作者所有,禁止商业用途转载。能,也就是rebase到一半的时候放弃,转载请注明出处:www.tangshuang.net转载请注明出处:www.tangshuang.net恢复原样。另外一个办法就是,rebase【版权所有】唐霜 www.tangshuang.net【作者:唐霜】的时候先以要rebase的分支创建一个分未经授权,禁止复制转载。本文作者:唐霜,转载请注明出处。支,这个分支跟rebase之前完全相同,【本文受版权保护】著作权归作者所有,禁止商业用途转载。如果rebase后后悔,可以切换到那个分【访问 www.tangshuang.net 获取更多精彩内容】【未经授权禁止转载】支。

未经授权,禁止复制转载。【关注微信公众号:wwwtangshuangnet】【访问 www.tangshuang.net 获取更多精彩内容】

rebase过程中发生conflict原创内容,盗版必究。

本文版权归作者所有,未经授权不得转载。原创内容,盗版必究。【版权所有】唐霜 www.tangshuang.net

这是最恐怖的一件事,特别是当你的comm【版权所有】唐霜 www.tangshuang.net原创内容,盗版必究。it特别多的时候发生conflict,你未经授权,禁止复制转载。未经授权,禁止复制转载。会崩溃。首先,conflict是怎么发生【转载请注明来源】【关注微信公众号:wwwtangshuangnet】的?其实是在上面提到的merge时发生的【转载请注明来源】著作权归作者所有,禁止商业用途转载。

著作权归作者所有,禁止商业用途转载。未经授权,禁止复制转载。【作者:唐霜】

再回到上面那张图。未经授权,禁止复制转载。
本文作者:唐霜,转载请注明出处。未经授权,禁止复制转载。 git-rebase-2
【未经授权禁止转载】【转载请注明来源】 当复制commit的过程发生时,实际上【未经授权禁止转载】【未经授权禁止转载】也发生着merge。很明显,从a到b,m【转载请注明来源】著作权归作者所有,禁止商业用途转载。aster分支上也发生着变化,这个变化可著作权归作者所有,禁止商业用途转载。【转载请注明来源】能会导致merge原来的dev分支的代码【本文首发于唐霜的博客】【版权所有,侵权必究】时,产生冲突。比如在老的dev分支上改了本文作者:唐霜,转载请注明出处。本文作者:唐霜,转载请注明出处。的某一段代码,在master分支上也发生本文版权归作者所有,未经授权不得转载。【本文受版权保护】了变化。这就是我文章一开头的时候遇到的问【版权所有】唐霜 www.tangshuang.net原创内容,盗版必究。题,也就是前面merge了一个程序员的代【原创内容,转载请注明出处】转载请注明出处:www.tangshuang.net码,现在merge你的代码时,confl【未经授权禁止转载】【版权所有】唐霜 www.tangshuang.netict产生了。

【版权所有,侵权必究】【关注微信公众号:wwwtangshuangnet】【访问 www.tangshuang.net 获取更多精彩内容】转载请注明出处:www.tangshuang.net【版权所有】唐霜 www.tangshuang.net

更恐怖的是,rebase每复制一个com未经授权,禁止复制转载。【转载请注明来源】mit都会去merge一次,这是因为对于【本文受版权保护】【本文受版权保护】新的dev而言,它的base已经改变了,【版权所有,侵权必究】本文作者:唐霜,转载请注明出处。每一个commit其实是从原来的dev中本文版权归作者所有,未经授权不得转载。本文版权归作者所有,未经授权不得转载。将代码合并过来,所以很有可能新的dev中原创内容,盗版必究。【版权所有】唐霜 www.tangshuang.net的代码和要合并的代码会产生冲突。

【本文受版权保护】【未经授权禁止转载】【原创内容,转载请注明出处】【版权所有,侵权必究】本文版权归作者所有,未经授权不得转载。

这也是为什么我们【本文首发于唐霜的博客】每一次git rebase –本文作者:唐霜,转载请注明出处。【作者:唐霜】;continue都有可能产生confl【关注微信公众号:wwwtangshuangnet】著作权归作者所有,禁止商业用途转载。ict的原因。著作权归作者所有,禁止商业用途转载。

本文版权归作者所有,未经授权不得转载。【本文首发于唐霜的博客】【未经授权禁止转载】【未经授权禁止转载】

更有可能,你的commit中前一个加入了著作权归作者所有,禁止商业用途转载。【未经授权禁止转载】某串代码,后一个commit又把它删除了本文作者:唐霜,转载请注明出处。【版权所有,侵权必究】,那么你在rebase的时候如果发生co本文版权归作者所有,未经授权不得转载。【访问 www.tangshuang.net 获取更多精彩内容】nflict的话,你不得不先解决第一个c转载请注明出处:www.tangshuang.net【本文首发于唐霜的博客】ommit的问题,然后解决第二个comm【未经授权禁止转载】【版权所有】唐霜 www.tangshuang.netit的问题,这种蛋疼的问题,都是无可救药原创内容,盗版必究。【作者:唐霜】的rebase造成的。所以,不在万不得已【本文受版权保护】【转载请注明来源】的时候,不要rebase啊!

本文作者:唐霜,转载请注明出处。未经授权,禁止复制转载。【本文首发于唐霜的博客】【作者:唐霜】转载请注明出处:www.tangshuang.net

因此,如果你要rebase的分支原来的b【版权所有,侵权必究】【转载请注明来源】ase节点越老、commit次数越多,那【本文受版权保护】本文版权归作者所有,未经授权不得转载。么出现conflict的次数也就可能越多转载请注明出处:www.tangshuang.net本文作者:唐霜,转载请注明出处。。反过来说,如果你要rebase的分支只【原创不易,请尊重版权】著作权归作者所有,禁止商业用途转载。有一个commit,那么即使出现conf未经授权,禁止复制转载。著作权归作者所有,禁止商业用途转载。lict,也只需要你解决一次就可以完成r【作者:唐霜】转载请注明出处:www.tangshuang.netebase。

著作权归作者所有,禁止商业用途转载。转载请注明出处:www.tangshuang.net【访问 www.tangshuang.net 获取更多精彩内容】

让我们来看下曲线救国的方法:未经授权,禁止复制转载。
转载请注明出处:www.tangshuang.net【版权所有】唐霜 www.tangshuang.net git-rebase-3
【转载请注明来源】【未经授权禁止转载】 就是用一个新分支先把dev的代码整合过原创内容,盗版必究。【版权所有,侵权必究】来(注意不是merge,merge会把所转载请注明出处:www.tangshuang.net原创内容,盗版必究。有的commit都包含)然后用这个新分支转载请注明出处:www.tangshuang.net【本文首发于唐霜的博客】去rebase,这样只需要解决一次con未经授权,禁止复制转载。原创内容,盗版必究。flict,当然,这样会损失所有的com【原创不易,请尊重版权】【未经授权禁止转载】mit,看情况是不是采取这样的方案。怎么转载请注明出处:www.tangshuang.net【转载请注明来源】整合代码呢?就是先把dev merge进本文版权归作者所有,未经授权不得转载。【版权所有】唐霜 www.tangshuang.netdev1,merge完之后dev1包含了【访问 www.tangshuang.net 获取更多精彩内容】【本文首发于唐霜的博客】所有的dev的commit,这个时候使用【转载请注明来源】【本文首发于唐霜的博客】reset –soft,把所本文版权归作者所有,未经授权不得转载。转载请注明出处:www.tangshuang.net有的commit取消,但是merge的时【版权所有,侵权必究】【转载请注明来源】候解决好的conflict的代码还在,所【未经授权禁止转载】【转载请注明来源】以只需要再commit一次,这样就实际上【原创内容,转载请注明出处】【原创内容,转载请注明出处】拥有了dev的最新代码,完成之后再reb本文作者:唐霜,转载请注明出处。【原创不易,请尊重版权】ase到b。

【本文首发于唐霜的博客】转载请注明出处:www.tangshuang.net本文版权归作者所有,未经授权不得转载。未经授权,禁止复制转载。【本文首发于唐霜的博客】

小结原创内容,盗版必究。

著作权归作者所有,禁止商业用途转载。著作权归作者所有,禁止商业用途转载。【转载请注明来源】【访问 www.tangshuang.net 获取更多精彩内容】

其实本文最核心的是要抓住rebase的运【版权所有】唐霜 www.tangshuang.net本文版权归作者所有,未经授权不得转载。动过程,一旦知道rebase是一个一个c本文作者:唐霜,转载请注明出处。【版权所有,侵权必究】ommit重新提交的一个全新的分支,就知【关注微信公众号:wwwtangshuangnet】【未经授权禁止转载】道为什么rebase的时候会出现那么多状原创内容,盗版必究。本文作者:唐霜,转载请注明出处。况了。

【版权所有】唐霜 www.tangshuang.net本文版权归作者所有,未经授权不得转载。【未经授权禁止转载】【版权所有,侵权必究】【版权所有】唐霜 www.tangshuang.net

2016-12-07 7712 , , ,

为价值买单,打赏一杯咖啡

本文价值77.12RMB