Using Git Rebase to Manage Commit History
使用场景
在开发过程中,可能会有这样的情况:你在开发一个功能时,提交了多次 commit,但是这些 commit 并不是一个完整的功能,或者是一个 bug 修复,这时候你可能会想要将这些 commit 合并成一个 commit,以便于更好的管理提交历史。这时候,git rebase 就派上用场了。通过这个命令,对 git 提交历史进行整理,可以使提交历史更加清晰。需要注意的是,如果你已经将这些 commit 推送到了远程仓库,那么你需要使用git push --force
来推送你的更改。
Commands:
p, pick = use commit
r, reword = use commit, but edit the commit message
e, edit = use commit, but stop for amending
s, squash = use commit, but meld into previous commit
f, fixup = like "squash", but discard this commit's log message
x, exec = run command (the rest of the line) using shell
d, drop = remove commit
合并多个 commit
如何确定你想要合并的 commits 的范围呢?
例如,如果你想要合并最近的三个 commit,你可以使用 HEAD~3
。这将打开一个编辑器(core.editor),列出最近的三个 commit。
你也可以使用git rebase -i <commit>
指定 commit 的 hash 值。例如git rebase -i 8c0a3c
,这将打开一个编辑器,列出从
运行git rebase -i HEAD~3
。
注意:git rebase 只能合并连续的 commit,如果你想要合并不连续的 commit,你需要多次运行 rebase 命令
你可以通过设置环境变量来指定使用的编辑器,例如:git config --global core.editor "nvim"
将使用 nvim 编辑器。
这里推荐lazyvim以及 lunarvim,这两个 vim 配置都是基于 neovim 的,功能强大,配置简单,推荐使用。且对于在终端中运行支持良好。
在编辑器中,将第二行和第三行的 pick 改为 squash 或 s;然后保存修改并退出,这将打开另一个编辑器,让你编辑新的 commit 信息。更多命令见下表 Commands 内容
vim 使用命令
2,3s/pick/s
可替换 2-3 行的pick
为squash
2,3
指定行;s/tom/jack/
表示 Substitute tom with jack;
编辑 commit 信息,然后保存并关闭编辑器。如果一切顺利,你的三个 commit 现在应该已经被合并成一个了。
这将改变你的 Git 历史。如果你已经将这些 commit 推送到了远程仓库,你将需要使用git push --force
来推送你的更改
修改 commit
如下是一个 git 提交历史,to fix
提交中有处错误,1 == 2
,要修改该提交中的错误可以使用git rebase -i HEAD~2
此时的 commit 历史如下:
Ref
Using Git Rebase to Manage Commit History