工作的时候遇到的git版本冲突与合并问题

问题的本质在于对Git对象模型引用系统的理解深度。遇到git问题的时候,不要慌张,什么问题都是可以解决的,只是还没用习惯,然后下面是git的几个区域以及代码在之间的流动过程示意图。

接下里就分享一下我在工作中遇到的实际的git问题以及解决方案:

1、release分支合错子分支了,还没push到远程仓库,怎么办?

描述:比如要发版合代码了,本来是要A分支合到release分支上了,结果把B分支合上面了

操作:git merge

分析:当我们merge之后,A分支的代码已经全部到了release分支的本地仓库中,只要还没push就问题不大,因为还只是在你自己的电脑上
解决方案 :直接删掉本地(Local)的release分支

然后fetch远程(remote)仓库(不是必要操作)

再check out release分支

就把远程仓库还没有污染的代码拉到了本地,本地已经污染的就直接被删除了,然后再正常把B分支的代码合过来,再push即可

2、release分支合错子分支了,已经push到远程仓库,怎么办?

描述:比如要发版合代码了,本来是要A分支合到release分支上了,结果把B分支合上面了,而且已经推送到远程仓库上去了

操作:git merge + git push

分析:当push之后,错的代码已经全都进远程仓库了,如果此时别人来拉的话就会把污染的代码全拉走,但是也不要慌,有解决方法
解决方案 :首先找到合B分支之前的那条记录,然后reset

选择Hard模式

然后再git push -f 强制推送,即可把release分支恢复到干净的版本了

3、在错误的分支上提交了代码

描述:比如需要在A分支上改一个bug,但是改到B分支了,并且暂存或者提交了

操作:git commit / git push

分析:这边推荐使用cherry pick实现不同分支之间的改动平移
解决方案 :切换到A分支,然后在git log中找到B分支暂存/提交的那条(多条)记录,然后直接cherry pick

在A分支直接push即可,然后回到B分支进行revert、push即可完成

先暂时记录到这,后面遇到类似的问题依旧持续更新

相关推荐
BestOrNothing_20152 小时前
Git fetch 详解:git fetch 和 git fetch origin 到底有什么区别?(origin/xxx、远端跟踪分支一次讲透)
git·分支管理·开发规范·新手教程·fetch / origin·本地/远程 分支·detached head
gsls2008082 小时前
服务器状态监控Uptime Kuma
运维·服务器·git
Star_KeyW12 小时前
【最新】Git简介与完整安装
git
深紫色的三北六号16 小时前
基于 Git 某个分支创建一个全新的仓库(GitHub / GitLab)
git·gitlab·github
-拟墨画扇-18 小时前
Git | 标签操作
git·gitee·github·gitcode
狂龙骄子18 小时前
使用git filter-branch命令修改历史提交
git·filter-branch·迁移仓库历史·所有权转移·修改历史提交
C2X18 小时前
关于Git Graph展示图的理解
前端·git
CryptoRzz18 小时前
StockTV API 对接全攻略(股票、期货、IPO)
java·javascript·git·web3·区块链·github
-拟墨画扇-19 小时前
Git | 远程仓库操作
git·gitee·github