Git reset revert区别

昨天手残 然后在GitHub for windows 上点了revert 然后就给重置了 更手残的是又给同步了 . 但是 GitHub 会保留之前的版本 . 只要删掉本次修改就可.

解决方案: gitshell ->> git revert HEAD

还原已经提交的修改
此次操作之前和之后的commit和history都会保留,并且把这次撤销作为一次最新的提交
git revert HEAD 撤销前一次 commit
git revert HEAD^ 撤销前前一次 commit
git revert commit-id (比如:fa042ce57ebbe5bb9c8db709f719cec2c58ee7ff)撤销指定的版本,撤销也会作为一次提交进行保存。
git revert是提交一个新的版本,将需要revert的版本的内容再反向修改回去,版本会递增,不影响之前提交的内容。

1.reset revert区别

  • git reset是直接删除指定的commit,把HEAD后移动了一下

  • git revert是一次新的特殊的commit,HEAD继续前进,本质和普通add commit一样,仅仅是commit内容很特殊:提交的内容是与前面普通commit文本变化的反操作。比如前面普通commit是增加一行a,那么revert内容就是删除一行a

    由于reset方式HEAD指针后移,推送到远端时需要有强制更新权限或者删除分支权限,公司gforge设有权限限制,走不通。

2.revert commit

仅仅用于非merge操作的普通commit

假设按时间顺序依次有commit1, commit2, commit3,commit4,对应有version1, version2, version3, version4四个状态.

  • revert某次commit(例子中commit4,commit4不是merge,那么revert后包括commit4以及后面的commit都会被抵消,最终文件状态为commit4前,即version 3状态)

    git revert commit4

[master 3a2ea91] Revert "version 4"
1 file changed, 1 insertion(+), 2 deletions(-)</pre>

git status

位于分支 master

#您的分支领先 'origin/master' 共 1 个提交。#   (使用 "git push" 来发布您的本地提交)
#
无文件要提交,干净的工作区</pre>

此时git push即可推送至远端

push后有commit5(commit5即本次convert操作),对应着version5,刚好version5与version3的文件状态一致,因为version4及以后的修改被抵消掉了.

revert过程有可能遇到冲突,要么git revert --abort终止此次revert操作,代码还原至revert命令前。要么手动消除冲突(同普通的冲突解决),然后add commit

3.revert merge

适用于merge操作的commit

假设当前状态:

commit 94ce4b8dcb898f730e6eecd73c00491f8020b67e
Merge: a2471f3 6a17d85
本次属于merge commit,注意Merge 标注
Author: 罗** luo**@youku.com
Date: Fri May 20 11:03:53 2016 +0800

merge

commit a2471f331c36a21d25aa158668cdc05987eef114
Author: 罗** luo**@youku.com
Date: Fri May 20 11:03:01 2016 +0800

verison 9

commit 6a17d85b04e52eddeb2ecb2a311804e10dada1e6
Author: 罗** luo**@youku.com
Date: Fri May 20 11:02:10 2016 +0800

version 8

commit 9441871ec2ff071e1a5be41646a32b2aea0b5502
Author: 罗** luo**@youku.com
Date: Fri May 20 10:56:08 2016 +0800

version 7

</pre>

可以看到94ce4b8是一次merge commit,Merge 标注为Merge: a2471f3 6a17d85,意思是说当前分支commit a2471f3(version 9),加上来自其他分支的commit 6a17d85(version 8).此时要撤销94ce4b8所表示的merge.

如果不指定-m参数

git revert 94ce4b8dcb898f730e6eecd73c00491f8020b67e
error: 提交 94ce4b8dcb898f730e6eecd73c00491f8020b67e 是一个合并提交但未提供 -m 选项。
fatal: 还原失败
</pre>

指定-m参数

git revert 94ce4b8dcb898f730e6eecd73c00491f8020b67e -m 2

位于分支 develop

无文件要提交,干净的工作区
</pre>

-m参数含义:Merge 标注为Merge: a2471f3 6a17d85,传1表示撤销到a2471f3所代表的commit,传2表示撤销到6a17d85所代表的commit。数字1,2表示的是标注冒号后的位置编号

上面例子中传参-m 2,所以撤销到6a17d85,最终文件状态与6a17d85 commit后一致(注意与上文差异),本例子中结果状态是“version 8”,不是version 7, git log确认结果如下:

commit 290c2f72d8d56d6be1008807450d4635095a549b
Author: 罗** luo**@youku.com
Date: Fri May 20 11:32:34 2016 +0800

Revert "merge"

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

推荐阅读更多精彩内容

  • git常用命令 GIT常用命令备忘:http://stormzhang.com/git/2014/01/27/gi...
    新篇章阅读 8,456评论 1 26
  • Git是目前最流行的版本管理系统,也是最先进的分布式版本控制系统(distributed version cont...
    pro648阅读 5,678评论 1 17
  • 枫林渐绿春犹在, 烟雨飘薄栖霞山。 今朝苦修苟且过, 斋行佛语心中留。
    青衣庆庆阅读 221评论 0 0
  • 你经常便秘吗?你常因为胃部不舒服的感觉打破了原本平静的生活吗?我们每天都吃这么多的食物,有时我们甚至不知道哪些是好...
    阳阳妈咪girl阅读 1,224评论 0 1