Git rebase 是版本控制系统 Git 中一个功能强大、使用广泛的命令。它用于将一个分支中的改动整合到另一个分支中。rebase与merge不同, merge会创建一个新的提交,而rebase则是将一系列提交移动或合并到一个新的基础提交中。下面是详细解释:
Git Rebase 的作用是什么?
rebase的本质是将当前分支的提交重新应用到另一个基础提交上。这通常用于保持线性的项目历史,避免产生不必要的合并提交。
Git 重定向的工作原理
请看下面的例子,feature
分支基于main
分支的一个较早提交:
A---B---C---D main
\
E---F---G feature
如果您在feature
分支上运行 git rebase main
,Git 会:
- 识别分支的共同祖先(本例中为
B
)。 - 确定自共同祖先(
E
、F
和G
)以来,feature
中每次提交所引入的差异。 - 从
feature
分支中暂时删除这些提交。 - 将
main
分支中的提交应用到当前提交 (A-B-C-D
)。 - 将
E
、F
和G
提交引入的改动重新应用到D
分支之上。
重定向后,历史记录将如下所示:
A---B---C---D main
\
E'---F'---G' feature
注意 E
、F
和 G
已经被新的提交版本 E'
、F'
和 G'
取代。这些新提交的改动相同,但提交哈希值不同,因为它们现在基于 D
。
重置基准命令
-
交互式重置:
git rebase -i <base-branch>
。- 允许编辑、重新排序、压制或删除提交。
-
常规重置:
git rebase <base-branch>
- 简单地将当前分支的提交重新应用到指定的基本分支上。
Git 重置基准的好处
- 更简洁的历史: 线性历史,没有不必要的合并提交。
- 更易于阅读&