一句话,git rebase 能够帮助项目中的提交历史干净整洁!!!git
一、新建一个 develop 分支shell
二、在develop分支上新建两个文件app
三、而后分别执行 add、commit、push工具
四、接着切换到master分支spa
分别添加c.txt 和 d.txt两个文件,分别进行add、commit、push3d
五、如今想把develop分支上开发的部分合并到master分支上日志
六、git merge 会将master和develop合并的过程经过以下形式展现出来。blog
借助 gitk 命令索引
借助sourceTree工具开发
若是master和develop分支上的这些开发部分都是同一我的操做,在合并的时候不想产生这种分叉的结果,怎么办呢?
git-rebase命令简介:用在从上游分支获取最新commit信息,并有机的将当前分支和上游分支进行合并。由于develop分支是在master分支基础上创建的,因此master称为topic的上游分支。
一、首先经过 git reset 恢复到master合并以前的状态
二、切换到develop分支,执行以下操做
三、若是你想把 rebase 以后的 master 分支推送到远程仓库,Git 会阻止你这么作,由于两个分支包含冲突。但你能够传入 –force 标记来强行推送。
四、查看一下develop分支合并的效果,以下。
看一下rebase的结果,就像是develop先把本身的提交保存起来,而后将master中的提交合并过来,最后在加上自身分支的提交,这样就不存在分支的合并效果了。
五、接着切换到master分支,执行git merge 操做就能够了
这时候,master和develop分支已经同步了。
在rebase的过程当中,也许会出现冲突(conflict). 在这种状况,Git会中止rebase并会让你去解决 冲突;在解决完冲突后,用"git-add"命令去更新这些内容的索引(index),而后你无需执行 git-commit,只要执行 git rebase --continue。这样git会继续应用(apply)余下的补丁。在任什么时候候,你能够用--abort参数来终止rebase的行动,而且"mywork" 分支会回到rebase开始前的状态。即git rebase --abort。
git rebase -i [startpoint] [endpoint]
其中-i的意思是--interactive,即弹出交互式的界面让用户编辑完成合并操做,[startpoint] [endpoint]则指定了一个编辑区间,若是不指定[endpoint],则该区间的终点默认是当前分支HEAD所指向的commit(注:该区间指定的是一个前开后闭的区间)。
在查看到了log日志后,咱们运行如下命令:
git rebase -i 0bb85c 582db9
或者
git rebase -i HEAD~3
上面未被注释的部分列出的是咱们本次rebase操做包含的全部提交,下面注释部分是git为咱们提供的命令说明。每个commit id 前面的pick表示指令类型,git 为咱们提供了如下几个命令:
pick:保留该commit(缩写:p)
reword:保留该commit,但我须要修改该commit的注释(缩写:r)
edit:保留该commit, 但我要停下来修改该提交(不只仅修改注释)(缩写:e)
squash:将该commit和前一个commit合并(缩写:s)
fixup:将该commit和前一个commit合并,但我不要保留该提交的注释信息(缩写:f)
exec:执行shell命令(缩写:x)
drop:我要丢弃该commit(缩写:d)
一、git rebase -i HEAD~3
二、编辑合并信息
三、修改commit信息
四、commit信息预览
五、commit合并结果
六、能够看到master上以后又1条提交记录了,而develop上还有3个提交记录
仍是要经过 git push -f 命令将合并的commit结果提交的远程仓库中。
若是develop分支也想要变成master分支这种合并效果,记住不要使用git merge 命令,还时会出现分叉的状况。继续使用 git rebase master命令。
git commit –fixup 自动在commit消息前添加fixup!关键字。
git rebase -i –autosquash 使用rebase自动合并被标记为fixup!的commit,实际上是根据sha值来的。
1.继续修复以下图所示对应的bug
二、修改完以后执行 git commit --fixup 须要合并的commit id
三、commit fixup 以后的效果
四、执行git rebase -i --autosquash 须要合并commit id的父级commit id
或者
git rebase -i --autosquash commit id^
五、执行rebase autosquash结果