git reset vs git revert

  sonic0002        2019-02-02 08:26:39       106,644        14          English  简体中文  繁体中文  ภาษาไทย  Tiếng Việt 

当使用诸如 git 等版本控制系统维护代码时,不可避免地需要回滚一些错误的提交,这可能是由于错误或临时代码回退导致的。在这种情况下,新手开发人员会非常紧张,因为他们可能会迷失在应该如何回滚更改而不影响其他人的问题上,但对于经验丰富的开发人员来说,这是他们的日常工作,他们可以向您展示不同的方法。

在这篇文章中,我们将介绍开发人员经常使用的两种主要方法。

  • git reset
  • git revert

它们之间的区别和对应的用例是什么?我们将在下面详细讨论它们。

git reset

假设我们有以下几个提交。

提交 A 和 B 是有效的提交,但提交 C 和 D 是错误的提交。现在我们想回滚到提交 B 并删除提交 C 和 D。当前 HEAD 指向提交 D 5lk4er,我们只需要将 HEAD 指向提交 B a0fvf8 即可实现我们想要的目标。

使用 git reset 命令很容易。

git reset --hard a0fvf8

执行上述命令后,HEAD 将指向提交 B。

但是现在远程 origin 的 HEAD 仍然指向提交 D,如果我们直接使用 git push 来推送更改,它将不会更新远程仓库,我们需要添加一个 -f 选项来强制推送更改。

git push -f

这种方法的缺点是,一旦完成重置,HEAD 之后的所有提交都将消失。万一有一天我们发现其中一些提交是好的,并且想保留它们,那就太晚了。因此,许多公司禁止使用此方法来回滚更改。

git revert

使用 git revert 是为了创建一个新的提交,该提交会还原之前的提交。HEAD 将指向新的还原提交。

对于上面 git reset 的示例,我们需要做的就是还原提交 D,然后还原提交 C。

git revert 5lk4er
git revert 76sdeb

现在它创建了两个新的提交 D' 和 C',

在上面的示例中,我们只有两个提交要还原,因此我们可以逐个还原。但是,如果要还原的提交很多怎么办?我们确实可以还原一个范围。

git revert OLDER_COMMIT^..NEWER_COMMIT

此方法不会有 git reset 的缺点,它会将 HEAD 指向新创建的还原提交,并且可以直接将更改推送到远程,而无需使用 -f 选项。

现在让我们看一个更困难的例子。假设我们有三个提交,但错误的提交是第二个提交。

使用 git reset 回滚提交 B 不是一个好主意,因为我们需要保留提交 C,因为它是一个好的提交。现在我们可以还原提交 C 和 B,然后使用 cherry-pick 再次提交 C。

从上面的解释中,我们可以发现 git resetgit revert 之间的最大区别在于,git reset 会通过删除所需提交之后的所有更改将分支的状态重置为之前的状态,而 git revert 会通过创建新的还原提交并保留原始提交来重置为之前的状态。建议在企业环境中使用 git revert 而不是 git reset。

参考:https://kknews.cc/news/4najez2.html

GIT  GIT RESET  GIT REVERT 

       

  RELATED


  14 COMMENTS


Anonymous [Reply]@ 2019-02-03 08:11:41

Really hard to take anything you say seriously when you use the entire aplhabet for your hexadecimal SHA1 examples.

Anonymous [Reply]@ 2019-02-04 21:52:35

No need for that

Anonymous [Reply]@ 2019-02-05 07:25:42

On the contrary, it’s a good decision, since those strings are never going to match any actual SHAs. Sort of like how it’s good practice to use “example.com” in example URLs since it’s been reserved for that purpose. Since we don’t have any reserved SHAs (at least that I’m aware of) it’s better to use illegal ones.

Alan [Reply]@ 2019-02-03 08:46:00

Given a lot of commits to cherry pick, the more efficient way to handle this is a basic interactive git rebase of the last X commits, and you delete the line(s) of the commit(s) to be deleted. Easy!

Anonymous [Reply]@ 2019-02-03 15:26:14

The drawback of force pushing is not that some commits get lost. It's that you change the history of a public repositor, breaking everyone else's local copy and forcing them to fix it on their side. It's such a bad idea that most tools and hosting services don't even allow it by default.

Anonymous [Reply]@ 2019-02-03 19:25:49
yes, good point
Anonymous [Reply]@ 2024-03-10 06:51:25

That's what --force-with-lease is for and that is perfectly okay to do, even in a production environment.

cmbuckley [Reply]@ 2019-02-04 12:02:25
There’s absolutely no reason to revert C, B and then re-apply C in your last example. You can simply revert B.
Ke Pi [Reply]@ 2019-02-04 19:41:20

yes, agreed

Anonymous [Reply]@ 2019-02-04 21:53:21

https://google.com

Anonymous [Reply]@ 2019-02-04 22:12:51

You can also use `git checkout a1b2c3d4 -- filename` to check out older revisions and then recommit those changes. It works great for shared state files that shouldn't be stored in version control but sometimes are

Anonymous [Reply]@ 2019-11-18 13:30:02

Had a hard time finding a good explanation of either revert or reset - then I found yours that not only explains each one, but compares and contrasts the two. Excellent article, thanks for the information!

Anonymous [Reply]@ 2020-03-27 18:40:17

Found this really helpful ! Thank you so much !

Ke Pi [Reply]@ 2020-03-28 05:29:48

thank you for liking it :)



  RANDOM FUN

Theory and practice in action