手动合并到主分支参考

本文用于记录两个相关仓库从功能分支合并到主分支的通用流程。示例只使用泛化名称,复制到公开笔记时按需替换路径和分支名。

适用场景

  • 功能已经开发完成,并且已经在测试或生产环境验证过。
  • 需要把前端仓库和后端仓库的功能分支同步合并到 master
  • 两个仓库分别独立管理 Git 历史,需要分别检查、合并和推送。

合并前检查

先分别进入两个仓库,确认工作区干净:

bash 复制代码
cd <frontend-repo>
git status --short --branch

cd <backend-repo>
git status --short --branch

如果有未提交改动,先确认这些改动是否属于本次发布:

  • 属于本次发布:先提交到功能分支,再合并。
  • 不属于本次发布:先暂存到 stash,或切到新的临时分支保存。
  • 不确定来源:不要直接丢弃,先确认再处理。

拉取远端信息

分别获取远端主分支和功能分支:

bash 复制代码
cd <frontend-repo>
git fetch origin master <frontend-feature-branch>

cd <backend-repo>
git fetch origin master <backend-feature-branch>

检查本地 master 是否和远端一致:

bash 复制代码
git rev-list --left-right --count master...origin/master

输出 0 0 表示本地 master 与远端 master 一致。

检查功能分支相对 master 的提交数量:

bash 复制代码
git rev-list --left-right --count master...<feature-branch>

如果输出类似 0 69,表示 master 是功能分支祖先,可以使用 fast-forward 合并。

合并前端仓库

bash 复制代码
cd <frontend-repo>
git switch master
git merge --ff-only <frontend-feature-branch>

如果成功,会看到 Fast-forward。如果失败,说明不能快进合并,需要先检查是否有并行提交或冲突。

合并后端仓库

bash 复制代码
cd <backend-repo>
git switch master
git merge --ff-only <backend-feature-branch>

同样优先使用 --ff-only,这样主分支历史会保持线性,更容易回溯。

推送主分支

确认两个仓库合并成功后,分别推送:

bash 复制代码
cd <frontend-repo>
git push origin master

cd <backend-repo>
git push origin master

推送完成后,再确认主分支状态:

bash 复制代码
git status --short --branch
git log --oneline --decorate -5

如果不能 fast-forward

如果 git merge --ff-only <feature-branch> 报错,先不要强推。按下面顺序处理:

bash 复制代码
git fetch origin master <feature-branch>
git switch master
git pull --ff-only origin master
git merge <feature-branch>

如果出现冲突:

bash 复制代码
git status --short

打开冲突文件,保留正确内容后执行:

bash 复制代码
git add <resolved-files>
git commit
git push origin master

冲突处理完成后,建议至少运行一次项目自身的基础检查,例如类型检查、单元测试、构建或核心接口冒烟测试。

推荐核对清单

  • 工作区在合并前是干净的。
  • 本地 masterorigin/master 一致。
  • 功能分支已经包含本次要发布的全部提交。
  • 前端仓库已合并到 master
  • 后端仓库已合并到 master
  • 两个仓库的 master 都已推送远端。
  • 如有数据库变更,已确认线上应该执行的是增量 SQL,而不是全新初始化 SQL。
  • 如有部署流程,已确认部署使用的是更新后的 master

常用命令速查

bash 复制代码
git status --short --branch
git fetch origin master <feature-branch>
git rev-list --left-right --count master...origin/master
git rev-list --left-right --count master...<feature-branch>
git switch master
git merge --ff-only <feature-branch>
git push origin master
git log --oneline --decorate -5
相关推荐
大鱼>13 天前
大语言模型+物联网:LLM理解物理世界
物联网·struts·语言模型·多模态·aiot
AndrewHZ13 天前
【LLM技术全景】大模型能力探秘:In-Context Learning与思维链(CoT)
人工智能·语言模型·大模型·llm·cot·思维链·icl
生成论实验室13 天前
机器人:一个自主运动的系统
人工智能·算法·语言模型·机器人·自动驾驶·agi·安全架构
Data-Miner13 天前
大语言模型+智能体AI,122页PPT详解落地应用培训!
人工智能·microsoft·语言模型
枫叶林FYL14 天前
BRIDGE:多模态查询的强化学习对齐与文本检索重构
人工智能·语言模型
小小工匠14 天前
拆解大语言模型:从词向量到注意力机制的内部运行原理
人工智能·语言模型·自然语言处理
暮云星影14 天前
瑞芯微rk3588利用Rockchip NPU运行大语言模型(LLM)
arm开发·人工智能·语言模型·自然语言处理
生成论实验室14 天前
自动驾驶:一个自主运动的系统
人工智能·算法·机器学习·语言模型·机器人·自动驾驶·安全架构
searchforAI14 天前
啥是LLM?大语言模型从原理到选型的完整科普
人工智能·科技·深度学习·ai·语言模型·知识图谱·agent
MartinYeung514 天前
[论文学习]重新思考大型语言模型忘却目标:梯度视角与超越
人工智能·学习·语言模型