如何使用Git优雅的回滚实现

 更新时间:2020年07月21日 10:45:05   作者:方凳雅集  
这篇文章主要介绍了如何使用Git优雅的回滚实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

开发过程中,我们经常会遇到代码回滚的情况。正常人都知道,git 回滚有两大宝:

  • git revert
  • git reset

当我们在本地开发,还未 git push 到远端时,可以毫无顾忌的使用 git reset 进行回滚。更多的情况中,我们不仅 push 了,而且由于开发周期长,在开发过程中不断的 merge mastermerge other-branch 以发布到预发环境测试或者多需求合并测试。

突然

上线后用户投诉,需要马上下线本次需求中的 A、B、C,只保留 D、E、F,迅速回滚,不要影响更多用户。

撕逼?那肯定是来不及了。一群人在你背后眼巴巴地盯着你,就问你慌不慌...

接下来,我们来说说,如何在紧急回滚面前,镇定(假)自若(装)地进行 git 操作

简单场景

本地操作使用 git reset 随便玩玩就行了,我们主要讲讲 git revert

回滚“单一提交”

回滚“连续提交”

回滚一次“合并”

回滚合并时,如果直接使用 git revert mergeCommit 实际上是递归回滚里面的每一个节点,指定 -m 是指定以哪一个分支为主线,当前所在分支为 1,依次类推(一次合并多个分支时会 > 2,正常只有 1 和 2)

 

高级场景

如果我们遇到的问题都像上面一样,那怎么能体现一个程序员的价值?

回滚“混合场景”

如以下场景中,我们期望回归的节点之间含有一次合并导致我们无法一次回滚到位。有两种方式:

1. 按顺序见招拆招回滚(三次操作)

2. 先回滚 D + F,再回滚合并(两次操作)

【推荐】使用方案1,按顺序回滚会处理更少的 conflict,否则假设 D、F 是一系列提交合集,那么回滚成本很高

回滚有点复杂“混合场景”

如下的场景中,特殊的地方在于,我有一个 feature,搭车了一个 bugfix,我需要回滚需求但不回滚 bug

这种情况下,有两种选择:

回滚 G,通过 git 引一步一步回滚 F-F'-E‘-D'-C‘-E'‘(不滚)-D'‘(不滚)-C'‘(不滚) ,回滚 E+D 【推荐】回滚 G,回滚 F 丢弃 F',回滚 D+E,复原 C‘'..E‘' 比第一种方案更快更简单,不用处理第一种方案中的 conflict

git revert G
git revert F -m 1
git revert D..E
git cherry-pick C``
git cherry-pick D``
git cherry-pick E``

回滚复杂的”混合场景“

标注解释

  • 蓝色代表已经合并到远程分支 Master 生成了 tag
  • 红色代表需要回滚的 commit
  • 绿色代表正常 commit

场景解释 一开始你所在的团队接到一个需求,这个需求中可以分拆出一个自需求,最终可以实现两人并行开发

  • 两个人 Pa 和 Pb 分别在 Master 基础上创建了新分支
  • 在开发过程中 Master 上发布了两次 bugfix(v2、v3)
  • 由于需要在预发上持续测试,所以 Pa 主动合并了 Master
  • Pb 在自己分支 B‘ C' D‘ 中废弃了之前的旧逻辑和一些代码的小幅重构(稳定性更新),之后 一直在本地开发新功能 & 验证
  • 最后即将上线时需要合并自需求一起验证,验证后 Pb 发布了 v3
  • 后续又经过了一次 bugfix 发布了 v4
  • 结果,产品反悔了 WTF ???
  • 最后,要废弃新功能,需要重新设计产品,但是旧有逻辑仍然按原计划废弃 >> F(v2) + B'-D'

回滚方式

遇到这样的场景,一般有如下几种方案回滚:

  • 回到最新的远端 Master (v4) 手动识别需求代码进行人工删除 删除自己的代码还好,删除别人的代码就有点难度了,而且当提交量很大时很耗时耗力
  • 复制 F(v2) 替换 Master(v4),手动或应用 B'-D‘ commit 图示情况,直接复制粘贴是个便捷的方法,再次回复 B'-D' 也费不了多大事,只是手动操作难免失误,尤其是增加/删除文件的情况,复制粘贴容易出错
  • 【推荐】按时序回滚(O'-T‘、L'‘、F'‘-K'‘^、B'‘-C'‘、E'-N‘) 版本控制本来就是为了代码管理更便捷,使用 git 操作后面的人不仅能看懂回滚了哪些 / 如何回滚的 / 怎么处理回滚中的 conflict 的,如果回滚错了还可以回滚“回滚了的”操作
git revert N`..S`
// 仅回滚非 merge Master 节点,保留 Master 代码
git log B``^..L`` --first-parent --no-merges --pretty=format:%H | xargs | xargs git cherry-pick -n 
git revert E`..F`

最后多说一点

想要回滚不头痛,提前就要做好功课并且保持清晰的提交记录,否则几百个 commit 回滚起来就变成了一场灾难。提几个好方法

保持 Commit 清晰

  • 一次 commit 的做一件完整的事,不要掺杂别的需求和 bugfix,未完成需求前不要轻易提交编译代码;
  • commit 有清晰的描述

善用 rebase

  • 如果有几次 commit 干的是一件事,可以通过 rebase 合并,不要出现很多 init、update 之类的无效 log
  • 刚刚提交代码后,又想起来某个配置需要改个版本,可以先 commit,最后使用 rebase 清理一下版本树

多人并行开发,创建独立的分支进行合并测试 不要合并到某一个分支中,防止上线时间变化导致代码再次清洗

到此这篇关于如何使用Git优雅的回滚实现的文章就介绍到这了,更多相关Git 回滚内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 将Sublime Text 设置成中文版的完整教程

    将Sublime Text 设置成中文版的完整教程

    这篇文章主要介绍了将Sublime Text 设置成中文版的完整教程,需要自己添加之后才会有这一项,对Sublime Text中文版设置方法感兴趣的朋友一起看看吧
    2022-01-01
  • 编程人员阅读代码的一些小技巧分享

    编程人员阅读代码的一些小技巧分享

    阅读别人的代码作为研发人员是一件经常要做的事情。一个是学习新的编程语言的时候通过阅读别人的代码是个最佳的学习方法,另外是积累编程经验。
    2011-01-01
  • 调用无文档说明的 Web API过程描述

    调用无文档说明的 Web API过程描述

    这篇文章主要为大家介绍了调用无文档说明的Web API过程描述,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪<BR>
    2022-03-03
  • Clion、IEDA、pycharm的一些简单设置步骤(设置中文菜单、输出中文、字体大小、背景颜色主题)

    Clion、IEDA、pycharm的一些简单设置步骤(设置中文菜单、输出中文、字体大小、背景颜色主题)

    这篇文章主要介绍了Clion、IEDA、pycharm的一些简单设置步骤(设置中文菜单、输出中文、字体大小、背景颜色主题),本文通过图文并茂的形式给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-08-08
  • Git基本常用命令

    Git基本常用命令

    本文主要介绍了Git基本常用命令。具有很好的参考价值,下面跟着小编一起来看下吧
    2017-01-01
  • Wordpress 忘记密码的处理方法

    Wordpress 忘记密码的处理方法

    有时候不小心忘了wordpress的密码了,大家可以按照下面的方法试试。
    2009-05-05
  • windows开发记事本程序纪实(一)界面篇

    windows开发记事本程序纪实(一)界面篇

    这将是一个系列博文,后面会继续补充逻辑功能的开发的步骤。本节主要实现记事本的主界面设计,包括主界面窗口的构建、菜单的加入。虽然都是一些基本的操作,但是还是想将这些基本步骤完整地记录下来,以便后续验证。
    2014-08-08
  • Git常用场景使用方法

    Git常用场景使用方法

    这篇文章主要介绍了Git常用场景使用,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-08-08
  • 使用Postman生成的okhttp代码依赖

    使用Postman生成的okhttp代码依赖

    这篇文章主要介绍了使用Postman生成的okhttp代码依赖,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-01-01
  • 详解IDEA Git Reset 选项说明

    详解IDEA Git Reset 选项说明

    这篇文章主要介绍了详解IDEA Git Reset 选项说明,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08

最新评论