赞
踩
需求场景一 :
对某个小的功能点进行多次反复的修改提交,且已经提交到远程,导致commit记录过多,太过于杂乱无章,想要精简合并一些提交记录。
场景还原:
比如下图4个git commit记录,log1-log4,需要将他们合并成一个提交记录
解决方案:
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
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。