Git_Rebase_Conflict_Resolution

Gerrit 变基(Rebase)与冲突处理指南

在 OpenHarmony FFmpeg 移植过程中,由于多人协同开发或远程分支更新,经常会遇到 Gerrit 上的 Merge Conflict(合并冲突)。本文档详细记录了该问题的现象、原因、处理过程及最终结果。

1. 问题现象

1.1 Gerrit 网页端

在 Gerrit 提交页面,右上角显示红色的 Merge Conflict 标签。

提示信息:

"This change has merge conflicts. Download the patch and run 'git rebase'. Upload a new patchset after resolving all merge conflicts."

1.2 本地推送失败

在尝试使用 git push 更新补丁时,可能会遇到以下报错:

  • ! [remote rejected] HEAD -> refs/for/xxx (no new changes):提示没有新变化(因为 Commit Hash 没变,但父提交已落后)。
  • 或者直接提示无法推送到该分支。

2. 根因分析

  • 本地代码落后:本地分支的开发起点(Base)是旧的。在开发期间,远程目标分支已经合入了其他人的代码。
  • 物理冲突:远程最新的代码与你修改的代码在同一个文件的同一行(或相邻行)发生了变动,Git 无法自动合并。

3. 处理流程图

同步远程 -> 启动变基 -> 手动解冲突 -> 标记解决 -> 继续变基 -> 推送更新

4. 详细处理步骤

第一步:同步远程仓库

首先确保本地知道远程分支的最新的状态。

bash 复制代码
git fetch kaihong

第二步:启动变基 (Rebase)

将本地的提交"剪切"下来,暂时放在一边,然后将本地分支对齐到远程最新的提交,最后再把你的修改"贴"回去。

bash 复制代码
# 假设目标分支为 M_Feature_LiteosAArch64_20240820
git rebase kaihong/M_Feature_LiteosAArch64_20240820

第三步:手动解决冲突

如果在"贴回"过程中发生冲突,Git 会停下来并报错:
CONFLICT (content): Merge conflict in <文件名>

  1. 打开冲突文件 (如 ohos_config.sh)。
  2. 定位冲突标记
    • <<<<<<< HEAD:远程最新的代码。
    • =======:分割线。
    • >>>>>>> <commit_id>:你本地写的代码。
  3. 合并代码:根据业务逻辑,删掉标记行,保留正确的代码组合。

第四步:标记解决并继续

  1. 标记文件已修复

    bash 复制代码
    git add ohos_config.sh
  2. 继续完成变基

    bash 复制代码
    git rebase --continue

    注:此时会弹出编辑器让你确认 Commit 信息,直接保存退出即可。

第五步:推送新补丁集 (Patch Set)

变基完成后,本地的 Change-Id 保持不变,但 Commit Hash 会改变。

bash 复制代码
git push kaihong HEAD:refs/for/M_Feature_LiteosAArch64_20240820

5. 处理结果

  1. Gerrit 自动识别 :由于 Change-Id 没变,Gerrit 会自动将此次推送识别为该任务的 Patch Set 2
  2. 冲突消失 :由于你在本地已经完成了变基并解了冲突,网页端的红色 Merge Conflict 标签会自动消失。
  3. 代码对齐 :你的代码现在是基于服务器上最新的代码开发的,处于 Active 状态,可以正常由审核人(Reviewer)合入。

6. 核心细节提示

  • Change-Id vs Commit IDChange-Id 是 Gerrit 用来跟踪同一个任务的"身份证",必须保持不变;Commit ID 是 Git 的物理存档 ID,变基后必然会变。
  • 不要使用 Merge :在 Gerrit 流程中,严禁在本地使用 git merge 来解决冲突,必须使用 git rebase 以保持提交历史的线性。
相关推荐
云天AI实战派13 分钟前
跨境出海全流程实战:用 Medusa + Hyperswitch + ClickHouse 搭建落地页、支付订阅、客服工单与多语言 SEO 闭环
大数据·人工智能·clickhouse·独立开发·跨境出海·medusa
团象科技28 分钟前
中企赴欧跨境业务布局期 欧洲主权云服务的落地适配性观察
大数据
陕西企来客1 小时前
陕西旅游酒店 GEO 服务市场深度调查:AI 搜索优化格局与真实服务真相
大数据·人工智能·旅游
MemoriKu1 小时前
【端侧 AI 部署】MobileCLIP 导出 ONNX/TFLite 并发布到 Hugging Face 的完整实践
大数据·人工智能·elasticsearch·搜索引擎·重构·开源
VALENIAN瓦伦尼安教学设备1 小时前
激光对中仪应用行业及全球市场份额解析
大数据·人工智能·嵌入式硬件
像风一样的男人@1 小时前
warning: could not find UI helper ‘git-credential-manager-ui‘
git·ui
一次旅行2 小时前
AI 技术热点新闻简报|2026-05-30
大数据·人工智能
逸Y 仙X2 小时前
文章五:Elasticsearch安全通信
java·大数据·安全·elasticsearch·搜索引擎·全文检索·jenkins
HannahTx2 小时前
录音文件存在哪里方便整理查找?全场景存储方案对比
大数据
weixin_468466852 小时前
数据高效处理实战:从痛点解决到价值落地
大数据·python·自动化·数据处理