今天研究了一下git的rebase
rebase中文“变基” ,改变基础(挂载点)的意思
最基本的rebase xxx分支:
目前有两个分支:master主分支和newbranch分支。现在位于newbranch上面,log图:
运行:git rebase master
可以看到,该rebase命令把newbranch上的三个commit按顺序加到了master的后面,就好像是从master分支上提交了三个新的commit一样。
注意,虽然之前newbranch里的提交hash值和命令之后不一样,但其中包含的数据是一样的,hash值不一样是因为这已经是新的commit了。
也可以加- i参数,i代表交互interaction(交互)
这可以指定某几个commit 变基到另一个地方,使用方式: git rebase -i goWhere
其中goWhere是要rebase去的基点
比如当前仓库分支情况如下图所示:
然后如果我们运行git rebase master的话,那么系统会分析当前分支(branch1)和master是从哪个节点开始分开的(本例中显然就是c1),
那么就会把c1之后的branch1分支依次插接到master后面,如图所示:
但如果我们不想要这么多commit都被插接过去(现在这里有c2/c3/c4),但如果是正常的开发情况,我们自己的分支至少一天提交一次,开发周期算两周,那就是十几次。我们合到主分支上的时候不希望全部commit都合过去,只需要一个commit就好。
当然我们可以用merge squash,但我们又不希望分支图乱糟糟的。
这时候使用git rebase -i master,然后git会为你自动打开一个vi窗口,你可以选择其中每个commit你要还是不要,要的方式。
假设我们有一个feature_x分支。已经commit一个d7322aa。之后我们一直在努力为该功能添加新元素(新的commit),包括CSS中的一些更改。
现在,我们希望将最后三个commit压缩为一个,这样push的时候也不至于太多无用的commit。
我们要怎么做呢?很简单:
git rebase -i HEAD~3
这是我们会发现,我们进入编辑界面,并且显示内容如下:
这个界面是让我们告诉git该如何处理每个commit。这里我们想保留f392171这个commit,所以我们需要做的就是将以下两个commit合并到第一个上,我们将编辑界面的内容改成这样即可:
注意:不要合并已经push的commit……