Gitlab 线上合并冲突的坑

背景

在 GitLab 上发起 feature → uat 的合并请求时,遇到冲突;你选择在 GitLab 网页端 Resolve conflicts ,结果解决冲突时,GitLab 把 uat 分支的代码合并进了 feature 分支,导致 feature 分支被污染。

现象

feature/my-feature 分支也有 uat 的代码,不符合预期

原因

  • 在线 Resolve 的逻辑
    • GitLab 并不是「只处理 MR 的合并结果」,而是直接在 源分支(feature) 上生成一个「冲突解决 commit」。
    • 换句话说,你在线解决冲突时,GitLab 会修改 feature 分支,而不是只在 MR 合并时处理。
  • 结果
    • feature 分支上会多出一个 commit,里面包含了 uat 分支的冲突解决内容。
    • 于是,feature 分支就「看起来像是被合并过 uat」,从而造成污染。

解决方案

本地手动操作:

bash 复制代码
# 1. 切换到feature分支 
git checkout feature/my-feature

# 2. 手动合并uat的最新代码(模拟GitLab的自动操作) 
git merge origin/uat 

# 3. 本地解决冲突 
# 4. 提交并推送feature/my-feature
git push origin feature/my-feature
# 5. 此时MR可直接合并(无需线上resolve)

如果已经污染了 feature 分支怎么办?

如果你不想 feature 带上 uat 的代码,有两种修复方式:

方案 A:回滚 feature 的污染 commit

perl 复制代码
git checkout feature/my-feature
git log   # 找到污染的 merge/resolve commit
git revert <commit-id>
git push origin feature/my-feature

方案 B:强制 reset 到污染前的版本

(如果团队允许,且 feature 上没重要改动)

perl 复制代码
git checkout feature/my-feature
git reset --hard <正确的commit-id>
git push origin feature/my-feature -f

建议

  • 不要用 GitLab 在线冲突解决,除非是临时性的 hotfix。
  • 团队流程最好规定:冲突必须在本地解决
  • 如果必须线上解决,可以新建临时分支(resolve 分支),解决冲突后再合并,避免污染 feature。
相关推荐
AAA阿giao1 天前
在你的网页中嵌入 Coze 智能客服:一步步打造专属 AI Agent
前端·javascript·人工智能
AAA阿giao1 天前
深入解析 OOP 考题之 EditInPlace 类:从零开始掌握面向对象编程实战
前端·javascript·dom
时71 天前
利用requestIdleCallback优化Dom的更新性能
前端·性能优化·typescript
西西学代码1 天前
flutter---进度条(2)
前端·javascript·flutter
Apeng_09191 天前
vue+canvas实现按下鼠标绘制箭头
前端·javascript·vue.js
wordbaby1 天前
组件与外部世界的桥梁:一文读懂 useEffect 的核心机制
前端·react.js
wordbaby1 天前
永远不要欺骗 React:详解 useEffect 依赖规则与“闭包陷阱”
前端·react.js
火星数据-Tina1 天前
体彩数据API
前端·websocket
源码方舟1 天前
【华为云DevUI开发实战】
前端·vue.js·华为云
VOLUN1 天前
封装通用可视化大屏布局组件:Vue3打造高复用性的 ChartFlex/ChartFlexItem
前端·vue.js