Git中,rebase和merge操做都是将一个分支的更改合并到另外一个分支中,可是方式不一样。git
举个例子:如今有两个分支master和feature,分别有以下提交:code
git merge feature
cdn
merge操做将会自动产生一个新的commit,记录此次合并的提交信息,merge操做记录了真实的commit状况,包括每一个分支的详情。blog
git rebase feature
开发
rebase将从主分支的最后一次提交开始添加feature分支中的全部更改。it
never use it on public branches(不要在公共分支上使用)
io
若是你想要一个干净的,没有merge commit的线性历史树,那么你应该选择git rebase 若是你想保留完整的历史记录,而且想要避免重写commit history的风险,你应该选择使用git mergeast