当前位置: 首页 > news >正文

Git 中的 Rebase 与 Merge:原理、区别与最佳实践

文章目录

    • 1. 引言:为什么 Git 会有 rebase 和 merge 两种方式?
    • 2. Git Merge:保留真实历史的合并
      • 2.1 Merge 的基本思想
      • 2.2 Merge 的使用方式
      • 2.3 Merge 的优点
      • 2.4 Merge 的缺点
    • 3. Git Rebase:重写历史的“整理术”
      • 3.1 Rebase 的基本思想
      • 3.2 Rebase 的使用方式
      • 3.3 Rebase 的优点
      • 3.4 Rebase 的缺点
    • 4. Rebase 与 Merge 的核心区别
      • 操作位置对比
    • 5. 冲突处理上的区别
      • Merge 冲突
      • Rebase 冲突
    • 6. 一个重要原则
    • 7. 实战推荐用法
      • 场景 1:个人功能分支
      • 场景 2:合并到主分支
      • 场景 3:提交前整理 commit
    • 8. GitHub / GitLab 的最佳实践
    • 参考

1. 引言:为什么 Git 会有 rebase 和 merge 两种方式?

在团队开发中,我们经常会遇到这样的场景:

  • 多个人在同一个仓库并行开发
  • 主分支(main / master)在不断前进
  • 自己的功能分支需要同步最新代码

这时,Git 给我们提供了两种选择:

  • git merge
  • git rebase

它们都能“合并代码”,那到底有什么区别?


2. Git Merge:保留真实历史的合并

2.1 Merge 的基本思想

merge的核心思想是:

把两个分支的历史“汇合”在一起,并生成一个新的合并提交。

示意图如下:

A---B---C---D (main) \ / E---F (feature)

合并后:

A---B---C---D------M (main) \ / E---F----- (feature)

其中M是一个Merge Commit


2.2 Merge 的使用方式

gitcheckout maingitmerge feature

注意要合并的时候切换到目标分支


2.3 Merge 的优点

  • 不修改历史,绝对安全
  • 提交记录完整可追溯
  • 适合多人协作、公共分支

2.4 Merge 的缺点

  • 提交历史可能出现大量 merge commit
  • 日志图可能较为“杂乱”
  • 不利于线性回溯提交

3. Git Rebase:重写历史的“整理术”

3.1 Rebase 的基本思想

rebase的核心思想是:

把当前分支的提交“挪到”另一个分支的最新提交之后。

示意图:

A---B---C---D (main) \ E---F (feature)

Rebase 后:

A---B---C---D---E'---F' (feature)

注意:

  • E'F'新提交
  • 原来的EF已被替换

3.2 Rebase 的使用方式

gitcheckout featuregitrebase main

3.3 Rebase 的优点

  • 提交历史线性、干净
  • 更容易阅读和回滚
  • 非常适合整理本地提交

3.4 Rebase 的缺点

  • 重写提交历史
  • 如果操作不当,容易引发协作问题
  • 不适合已经推送到远程的公共分支

4. Rebase 与 Merge 的核心区别

维度mergerebase
是否生成新提交是(merge commit)否(重写提交)
历史是否线性
是否修改历史
风险程度
适用场景公共分支本地分支

操作位置对比

操作当前所在分支目标分支命令格式
git rebase当前分支要变基到的分支git rebase 目标分支
git merge当前分支要合并进来的分支git merge 来源分支

5. 冲突处理上的区别

Merge 冲突

  • 只解决一次冲突
  • 生成一个 merge commit

Rebase 冲突

  • 每一个提交都可能冲突
  • 需要多次git rebase --continue

6. 一个重要原则

永远不要 rebase 已经推送到远程的公共分支

原因:

  • 会改变提交 hash
  • 导致他人无法正常拉取代码
  • 可能引发灾难性冲突

7. 实战推荐用法

场景 1:个人功能分支

✅ 推荐 rebase

gitcheckout featuregitrebase main

目的:
👉 保持提交历史干净


场景 2:合并到主分支

✅ 推荐 merge

gitcheckout maingitmerge feature

目的:
👉 保留真实开发历史


场景 3:提交前整理 commit

gitrebase -i HEAD~3

可用于:

  • 合并提交
  • 修改提交信息
  • 删除无用提交

8. GitHub / GitLab 的最佳实践

  • 功能开发:rebase同步主分支
  • 最终合并:mergesquash merge
  • 禁止对main/master执行 rebase

参考

【五分钟学会git rebase和 git merge的区别】

Git:图解 merge 和 rebase 的区别

http://www.jsqmd.com/news/321787/

相关文章:

  • 实时音视频通信技术解析:WebRTC核心原理与实战
  • RISC-V IDE MRS2使用笔记(八):手动切换文件编码
  • 能为你加分的性能测试
  • B2B商城系统如何选择?解析千匠网络的三大核心优势
  • 前端框架演进史:从jQuery到Vue 3的架构变迁
  • 基于单片机的酒精监测系统
  • 口罩机通用程序 已经升级一拖一7,8,9,10 伺服口罩机通用程序架构, 程序高度模块化, 可...
  • 2026年4米2高栏货车经销商综合评估报告:重载运输场景首选品牌推荐
  • CrossFormer 实现图像分类以及视觉任务的骨干网络替换 它使用交替的局部和全局注意力击...
  • 计算机毕业设计之基于springboot的学测评系统设计与实现
  • 自动化测试框架搭建:Selenium与Pytest集成指南
  • 容器编排进阶:Kubernetes Operator设计与实现
  • 千匠网络助力省级龙头企业打造农产品供应链平台
  • 解锁飞行焊接:电芯顶盖封口的高效与精准密码
  • 普洱市英语雅思培训辅导机构推荐-2026权威出国雅思课程中心学校口碑排行榜
  • 2026年全国坚果炒货连锁批发巧克力生产厂家排行榜及全景解析与参考
  • 前端工程化实践:Webpack 5配置优化与插件开发
  • 别再瞎选场镜(F-Theta Lens)啦!焦距、光斑、景深关系大揭秘
  • vector 迭代器 数据插入和弹出时迭代器失效的原因
  • 千匠网络B2B商城系统:六大维度解析企业级数字化商业解决方案
  • 2026华东区域净化板、C 型钢、光伏板材推荐榜单发布:天腾彩钢迈向高质量发展新阶段
  • 云原生监控体系构建:Prometheus与Grafana实战
  • Libero PolarFire SoC reset 信号
  • 普洱市英语雅思培训辅导机构推荐,2026权威出国雅思课程中心学校口碑排行榜
  • claude code windwos上查询文件报错
  • 选购高空作业车,驰通智能品牌推荐靠谱吗?
  • 实测推荐:北京别墅大宅暖通机电选哪家?享舒适实力登顶首选
  • 移动端性能优化:Android与iOS内存管理深度剖析
  • NLIS01控制器模块
  • 释放Talkie能力,MiniMax发布角色扮演模型M2-her;Genspark推出AI听写工具,集成Agent模式丨日报