Git版本回退之 reset 和 revert

在开发过程中,可能会遇到过错误提交的情况。这种情况下,先不要着急,可以通过以下两个命令来帮助你优雅的实现版本回退。

git reset

假如现在有如下几个提交:[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-0R1EYqND-1631173827022)(C:\Users\apple\AppData\Roaming\Typora\typora-user-images\image-20210909145924975.png)]

其中:A 和 B 是正常提交,而 C 和 D 是错误提交。现在想把 C 和 D 回退掉。而此时HEAD 指针指向 D 提交(5lk4er)。我们只需将 HEAD 指针移动到 B 提交(a0fvf8),即可。

这个时候就可以使用git reset 命令:

git reset --hard a0fvf8 // 将HEAD指针移动到B提交点
git push origin HEAD --force // 将提交强制推到远程仓库

此时HEAD指针就会移动到 B 提交下
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-hktfQV8F-1631173788570)(C:\Users\apple\AppData\Roaming\Typora\typora-user-images\image-20210909151048438.png)]

采用这种方式回退代码会使 HEAD 指针往回移动,从而会失去之后的提交信息且不可恢复,所以要慎重使用。

git revert

git revert会创建一个新的版本,且HEAD指针会指向这个新生成的版本,原来错误提交信息也可以保留。

可以通过用git revert 命令逐个回退:

git revert 5lk4er
git revert 76sdeb

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-BOY0KjKx-1631173788571)(C:\Users\apple\AppData\Roaming\Typora\typora-user-images\image-20210909151934936.png)]回退版本少的可以逐个回退,多的话就要批量回退了:

git revert OLDER_COMMIT^..NEWER_COMMIT

通过对比发现,git reset 会失去后面的提交,而 git revert 是通过反做的方式重新创建一个新的提交,而保留原有的提交。所以应尽量使用 git revert 命令来回退版本,慎重使用 git reset 命令。

补充

假如现在有三个提交,不巧的是那个错误的提交刚好位于中间
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-dxlXu8o2-1631173788573)(C:\Users\apple\AppData\Roaming\Typora\typora-user-images\image-20210909153952226.png)]

此时直接使用 git reset 命令将 HEAD 指针重置到 A 提交显然是不行的,因为 C 提交是正确的,需要保留的。

正确的做法:先把 C 和 B 提交全部回退,再使用 cherry-pick 命令将 C 提交重新再生成一个新的提交 C’’,这样就实现了将 B提交回退的需求。

[外链图片转存中...(img-tJNkC0pb-1631173788574)]

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值