当前位置: 首页 > news >正文

关于 git reset --hard 引发的代码故障(附故障原因及解决方案)

背景

最近在开发中遇到一次飞醋严重的代码故障,同事 A 上线了一个需求,但是由于设计原因,需求代码要严重的线上故障,需要紧急回滚,除了部署回滚之外,同事 A 使用了 git reset --hard 进行的代码回滚,然后重新进行了部署发布,看起来是没有什么问题,但是在发布之后不久,团队内另外的同事 B 也发布了需求代码,这时候故障再次产生了,原因是同事 B 将同事 A 回滚的代码再次发布到了正式环境,

同事 B 在合并代码之前确实是再次合并了线上 master 的代码,那么问题来了,为什么同事 A 明明已经 reset 了代码,同事 B 为什么还能又给带到了正式环境

分析

分析后发现,git reset --hard 强制修改了 master 分支的历史提交记录,导致故障产生

完整操作如下

- commit 情况
- 线上 master 分支最新 log commit: "last commit" commit f655dcfb
last commit
同事 A 提交 commit "需求 1" 到 master 分支 commit f655dcfb1
需求1
commit f655dcfb
last commit
同事 B 从 master 分支切换了新的需求分支(此时带有 commit "需求 1" ) commit f655dcfb1
需求1
commit f655dcfb
last commit
同事 A 强制 git reset --hard 到 commit "需求 1" 之前的一个 commit,
也就是 "last commit"
并且执行了 git push -f
commit f655dcfb
last commit
同事 B 需求开发完成,提交 commit :“需求2 ”,合并了 master 分支的最新代码,
并且将新需求的代码合入了 master
commit f655dcfb2
需求2

commit f655dcfb1
需求1
commit f655dcfb
last commit

从操作上来看,虽然同事 A 线上 git reset --hard 了代码,但是如果其他同事本地仓库就有了这些代码,那么在合并的时候 git 无法识别哪些是被回滚的(因为没有历史记录,无法对比),只能认为这些新添加的

解决

在找到原因之后,解决方法也比较简单

关于 git 代码回滚的几种方案对比,请移步文章 Git 如何正确回滚代码?常见回滚操作对比,适用不同的场景

(一)方法一

不用 git reset --hard,改为 revert

git revert 不同于 --hard,会产生一个新的 commit,这样子其他同事本地 pull 的时 git 就能正确识别合并代码

(二)方法二

如果确实是需要使用 git reset --hard ,在使用之前需要提前和团队内其他成员进行沟通,确保其他成员本地仓库没有拉取你这些需要回滚的代码,才能确保最终代码正常

那么还有一个问题,已经使用了 git reset --hard,造成了代码故障了,也就是上述的情况,应该怎么处理解决?

这就需要团队其他成员检查本地分支是否已经合并了回滚的代码,使用

 # 重置本地 master 分支 或者直接删除重新 checkoutgit pull -fgit reset --hard origin/master# 当前分支和 origin/master 进行对比,会展示差异git diff origin/master

这应该是所有使用 git 的开发者在合并代码时的一个必备操作,很明显同事 B 并没有这样做

通过和 master 进行 diff,就可以展示哪些变动不是你修改的,选择丢弃即可

总结

  • 团队协作中,尽可能不用 git reset --hard

  • 合并代码时,一定要先进行 diff 合入分支,确保所有变动代码都是你改的(必做操作)

原文地址

关于 git reset --hard 引发的代码故障(附故障原因及解决方案)

http://www.sczhlp.com/news/10504/

相关文章:

  • 【典型案例】利用高光谱遥感技术进行稀有矿产勘探 - ENVI
  • 学 STM32 第一步:入门工具怎么选?避免新手常见误区
  • Flutter 布局控件使用详解 - 指南
  • LHA6958D是ADS8588的代替料
  • 惠普笔记本电脑开机黑屏,一直响三长两短的滴滴声
  • selinux
  • 【转】Windows Server 系统的桌面上显示 此电脑 图标
  • hj_2025_0812
  • CF2062G Permutation Factory 题解
  • NBD(Network Block Device)简介及基本使用
  • 2024年12月齐鲁弱校联考
  • SpingBoot分段输出日志并自动删除
  • GLM4.5V视觉模型小试牛刀
  • 牛x,这也许是Coze(字节)平替,AIFlowy:企业级AI应用开发平台
  • Petrozavodsk Summer 2024. Day 2. K-ontest
  • pygame小游戏飞机大战_6敌人开火
  • Git 如何正确回滚代码?常见回滚操作对比,适用不同的场景
  • 嵌入式数据库_sqlite-duckdb
  • 抱歉!Java面试标准答案最不重要
  • PyCharm安装教程(附安装包)超详细下载安装激活教程(新手零基础安装指南)
  • maven配置阿里云镜像加速
  • RAID 磁盘阵列
  • 题解:P10965 Largest Submatrix - e
  • 面试防坑场景
  • 夜莺开源监控,模板函数一览
  • 10 个不错的 C 语言开源项目
  • systemctl服务管理
  • 打编程之024:免费本地AI客户端-Chatbox和CherryStudio
  • 绩效考核管理系统横评:功能对比、应用场景与企业选择指南
  • Windows10 安装编译后的 pysqlcipher3-v1.2.1 基于 Python 3.11.9