1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > 使用Git rebase合并多条提交记录commit。以及使用 git commit amend本地提交直接

使用Git rebase合并多条提交记录commit。以及使用 git commit amend本地提交直接

时间:2021-11-15 15:45:45

相关推荐

使用Git rebase合并多条提交记录commit。以及使用 git commit amend本地提交直接

需求场景一 :

对某个小的功能点进行多次反复的修改提交,且已经提交到远程,导致commit记录过多,太过于杂乱无章,想要精简合并一些提交记录。

场景还原:

比如下图4个git commit记录,log1-log4,需要将他们合并成一个提交记录

解决方案:

要处理的是log1-log4 这四条commit记录。选中log1之前一条commit的commit id,也就是图中最下面这条。e65b97e332c0683631c334b870e0ceb062163815使用 git rebase 进入vim编辑器

git rebase -i e65b97e332c0683631c334b870e0ceb062163815

4.进入vim编辑器之后,单击 i 按键 进入编辑模式,这是最下方会出现-- INSERT --标识表示我们进入了编辑模式。

5. Commands 可以看到我们可以使用的命令以及缩写以及每个命令的缩写。这次要使用的命令的是pick和squash。

6.这时候最上方4个commit log1-log4的前面都是pick,移动光标将log2-log4前面的pick改为s(或者squash)

7. 编辑完毕之后,点击esc 然后按住 shift+";“双引号, 最底下出现冒号, 然后输入wq 回车 保存。

8. 这时候就能看到 我们之前提交的4个 commit 的 信息, 你可以选择在不要的message前面加个#号 表示忽略掉这条信息,一般来说去掉几个不要的,只保留一个进行编辑或者保持原始状态。比如 我在log1 3 4 前面加个#号表示忽略,对log2进行编辑 。(这里依然要点击i 进入编辑模式。)

9.编辑完之后的效果如下,我想要提交的合并信息就是"meger log1-4”,

重复上面的步骤 保存退出。esc=>:wq

10.如果成功会有一行提示

Successfully rebased and updated refs/heads/feature/git-test.

如果失败 可以使用 git rebase --continue 进入vim编辑器重新操作。

如果想要放弃这次编辑 可以使用git rebase --abort 命令中止本次操作。

11. 最后使用命令 git push -f 强制推送,大功告成。

需求场景二 :

对于已有一个提交记录push到远程, 但你本地目前有一点小的修改,想再推送到远程,但不想再生成一个提交记录,使得commit记录过多,且不想更改已有的commit message。

比如下图 有一个提交 my first commit commitId是7b3b6ada 时间是 16:47

解决方案 :

1.git add . 将要更改的代码提交。

2. 这时候 可以使用 git amend进行合并代码

git commit --amend --no-edit

3.最后强推到远程

git push -f

查看效果 git log。我们可以发现 提交时间和message没变,但是 commitId 从7b3b6ada 变成了3ac2a2d。

5.⚠️注意这个方法只适合只有一个开发者 或者自己单独一个开发分支的时候使用, 否则有可能会覆盖别人的代码,慎用 慎用。

使用Git rebase合并多条提交记录commit。以及使用 git commit amend本地提交直接合并到远程已有commit的用法

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。