代码Revert后再次Merge会丢失的问题

问题场景

公司团队使用的是gitLab进行代码管理。因为甲方临时变动,计划好已经要发版的功能突然说不上线了,所以需要将master分支进行revert,把merge到master上的功能分支revert。

当再次通知该功能上线,重新从功能分支dev提了merge请求到master时,发现代码变动都不显示了,导致无法合并。也就是说:被回滚的代码被认为已经存在于master分支上,不算改动。

原因分析

revert操作实际是只是进行了一次逆向commit,将merge的代码进行回滚,但是commit的记录还是存在的。也就是说,dev上面存在的待提交的代码,其实已经是master的过去代码,属于已提交过的状态,所以不会显示different。

解决方案

方案1:官方推荐方案

  • 核心:对revert的那次提交记录再次revert

(1)首先,切换到master分支,并基于master分支拉出一个revert_tmp。作为master的副本,revert_tmp的作用就是保存revert的提交记录;

css 复制代码
git checkout master

git checkout -b revert_tmp

(2)其次,在master分支上找到revert的那条提交记录的版本号,回滚至之前的版本(版本号可以通过git log 命令,或者网页端查看),此操作在 revert_tmp分支上进行操作

bash 复制代码
git log 
git revert 版本号

(3)然后,切换到dev分支上,将revert_tmp这个分支merge到dev分支上。

perl 复制代码
git checkout dev
git merge revert_tmp
git push -f

(4)最后,在dev重新提交对master的merge申请,会发现revert之前的代码都回来了。

方案2:reset方案

与revert不同,采用-- git reset将head向后移动动上一次merge前的commit版本,会丢弃所有的merge commit记录(revert 不会丢弃,是逆向commit),所以,再次合并不会出现记录不显示或者冲突的问题。

perl 复制代码
git reset HEAD^

git reset HEAD^^

HEAD说明

--hard参数 参数说明
HEAD 当前版本
HEAD^ 上一个版本
HEAD^^ 上上一个版本
HEAD^^^ 上上上一个版本
以此类推......
^可以使用 ~ 数字表示
HEAD~0 表示当前版本
HEAD~1 上一个版本
HEAD~2 上上一个版本
HEAD~3 上上上一个版本
以此类推......

参考并实践:

相关推荐
OsDepK4 小时前
OSMDE手机AI编程,一键Git
git·ai编程
用什么都重名10 小时前
Git分支合并与远程服务器同步实战:保留关键配置文件
运维·服务器·git
得要找到一束光10 小时前
git详细命令
git·github
2601_9618752412 小时前
花生十三公考课程|网课|视频
数据库·windows·git·svn·eclipse·github
EleganceJiaBao16 小时前
【Git】Git reset 完整指南:真正理解 HEAD、暂存区与工作区
git·github·reset
我最爱吃鱼香茄子17 小时前
【保姆级】Git配置用户名和邮箱(全局/局部)解决提交记录不识别、贡献图不亮问题
git·gitee·github·小白教程·git配置·程序员开发工具
weixin_5716674118 小时前
git fork 并建立自己的dev分支 保持与源仓库的联系
git
master33618 小时前
git仓库通过脚本完成多个远程仓库同步
大数据·git·elasticsearch
用什么都重名18 小时前
Git 合并两个无共同历史的分支:从报错到解决全记录
git·gitlab
2601_9618752418 小时前
花生十三资料网盘|百度云|下载
数据库·windows·git·svn·eclipse·github