Git - 回滚

回滚命令

git回滚的命令主要有如下几种:

  • git reset
  • git revert

git revert常用于回滚单个commit。详情见 Git - revert
git reset常用于回滚多个commit,或者回滚后重新修改。详情请见 Git - reset

场景

回滚某个commit

场景
提交了很多commit,想把某次commit的代码回滚。

commit 8abfadc33abe671ac44ca3c71e6310aac067c75d
commit ec3efbc7ba89a537c8f8d8a0f92102f36d5a1278
commit 66a69a7369dc4bd49ce44c83bb1bdc19c4600659

比如想回滚ec3efbc7ba89a537c8f8d8a0f92102f36d5a1278这个commit。

解决方法
可以用git revert命令

git revert ec3efbc7ba89a537c8f8d8a0f92102f36d5a1278

git revert会创建一个新的commit,这个新commit与原来commit操作完全相反,达到回滚效果。下面是revert时创建的新的commit:

commit e16a5425c124ae7af713ffbc2e4faf2ec33bb25d (HEAD -> test1)
Author: micheal <michealyang@qijin.com>
Date:   Sat Sep 29 17:25:57 2018 +0800

    Revert "[test1] 6"

    This reverts commit ec3efbc7ba89a537c8f8d8a0f92102f36d5a1278.

回滚到某个commit

场景
提交了很多commit,想把最近几次的commit都回滚掉。

commit 8abfadc33abe671ac44ca3c71e6310aac067c75d
commit ec3efbc7ba89a537c8f8d8a0f92102f36d5a1278
commit f50abb74fbf44c5d30a8e2fc3a42ebc3867f8a38

如,将代码回滚到f50abb74fbf44c5d30a8e2fc3a42ebc3867f8a38这次提交。

解决方法
有两种思路:

  • 需要回滚几个commit
  • 需要回滚到哪个commit

所谓“需要回滚几个commit”,是指知道哪几个commit是需要回滚的。有了这个数量,可以用如下命令回滚:

git reset HEAD~2

git reset HEAD@{2}

表示要回滚2个commit。这样正好回滚到f50abb74fbf44c5d30a8e2fc3a42ebc3867f8a38

所谓“需要回滚到哪个commit”,是指不需要知道要回滚几个commit,只需要知道要回滚到的commit id即可。上面的例子要回滚到需要回滚到f50abb74fbf44c5d30a8e2fc3a42ebc3867f8a38这个commit。那么,如下命令可以做到:

git reset f50abb74fbf44c5d30a8e2fc3a42ebc3867f8a38

这两种思路操作不同,但是最终达到的效果是一样的。

当然,根据需要,可以添加--hard, --soft--mixed等参数。
如:

git reset --mixed HEAD~2
等同于
git reset HEAD~2

表示回滚掉的代码依旧保留,还可以修改

git reset --hard HEAD~2

表示抛弃回滚掉的代码。

reset完成后,就可以通过git push把回滚后的结果同步到远程分支了。

恢复到与HEAD一致

场景
当修改了一些内容,并且提交到了本地。但是后来发现这些修改不用了,想完全回滚掉。

image.png

解决方法
这时,就可以通过如下命令,使本地分支的HEAD与远程分支的HEAD保持一致。

git reset --hard origin/master

命令执行完成后,本地分支的代码就与远程分支完全一样了。

回滚Merge

回滚最新的Merge

场景
假设有如下流程:

image.png

两个branch test2和test1分别被merge到了master中,test1最后merge
现在需要把test1的merge回滚掉。

解决方法
可使用如下任何一种方法:

git reset --merge ORIG_HEAD
git reset --hard ORIG_HEAD
git reset --hard HEAD~1
git reset --hard HEAD@{1}

上面三种命令都能实现,不过还是需要讲解下参数:

  • HEAD是当前最新的commit。ORIG_HEAD是上一次的commit。因此revert ORIG_HEAD的意思就是回滚到上次commit。ORIG_HEAD现在已经不常用了,完全可以用更灵活的HEAD@{1}替代
  • HEAD~n表示倒数第几个commit。HEAD~1就表示上一次commit,HEAD~2表示上上次commit,以此类推。HEAD@{n}与之同理

回滚中间的Merge

场景

  1. 在test1分支修改了一些东西
  2. 将test1分支merge到master
  3. 又有很多其他分支被merge到了master

这时master分支的git log如下图所示:


image.png

现在发现test1分支有重大bug,需要回滚。而merge完test1后,又有很多分支被merge到了master中。全量回滚不现实。那么怎么只回滚test1的提交呢?

解决方法
每个Merge操作会产生一个Merge commit。 Merge commit都会有Merge这个单词在git log中。如下图所示:

image.png

Merge单词后面还有两个commit号,是本次commit的parent commit。
所谓parent commit是指,master分支merge了test1分支,那么master分支中的最新commit和test1分支中的最新commit就是生成的Merge commit的parent commit。

上图中所示的7c544ac是master分支的最新commit。7b68089是test1分支的最新commit。在这里我们可以单独把其中的一个parent给revert掉。序号从1开始。

git revert -m 2 346774d0ccc018e4b0fb40695587cbd82d4299b3

其中-m参数后面跟着的就是要revert的parent commit的序号。
我们知道,revert命令会创建一个新的commit,执行完上面的操作后,查看git log会有如下结果:

image.png

这样,这个merge就被回滚了。

注:当有conflict的时候会比较麻烦

参考

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,186评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,858评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,620评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,888评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,009评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,149评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,204评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,956评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,385评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,698评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,863评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,544评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,185评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,899评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,141评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,684评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,750评论 2 351

推荐阅读更多精彩内容

  • 方法一,删除远程分支再提交 ①首先两步保证当前工作区是干净的,并且和远程分支代码一致 $ git co curre...
    那小白阅读 236评论 0 0
  • git常用命令 GIT常用命令备忘:http://stormzhang.com/git/2014/01/27/gi...
    新篇章阅读 8,458评论 1 26
  • git作为版本控制肯定是常见的了,对于git有一个版本回滚的功能是我们在开发过程中应该用到比较多,掌握它对于我们开...
    草帽小子J阅读 883评论 0 3
  • 学明行日记第 40篇 恩恩读经105周第5天 读经日期:2018年9月21日 星期五 阴 亲子读经内容: 1.易经...
    点亮喜乐富足的人生阅读 170评论 0 0
  • 在这无比美妙的端午佳节之日,外面无比炎热,在还算凉爽的宿舍里打开电脑看了朋友推荐的一部电影《逆光飞翔》。电影讲述了...
    Twinkle_______阅读 498评论 0 0