news 2026/4/4 18:24:18

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
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 的区别

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/1 20:52:25

基于LangChain手工测试用例生成工具

在编写测试用例的过程中,测试工程师会通过需求文档,研发的概要设计等信息编写测试用例,测试用例的输出格式常常为思维导图或者excel等数据信息。 在以上的流程中,一个测试工程师可以根据比较详细的需求文档以及研发的概要设计输出…

作者头像 李华
网站建设 2026/4/1 3:06:39

接口性能优化的11个小技巧

接口性能优化 对于从事后端开发的同学来说,肯定再熟悉不过了,因为它是一个跟开发语言无关的公共问题。 该问题说简单也简单,说复杂也复杂。 有时候,只需加个索引就能解决问题。 有时候,需要做代码重构。 有时候&am…

作者头像 李华
网站建设 2026/4/3 5:32:27

git个人开发流程

1. 标准开发流程 (针对个人项目) 第一步:同步主分支 (保持起点最新) # 1. 切换回主分支 git checkout main# 2. 拉取远程最新代码 (防止你在这个设备开发时,在另一个设备Push过代码) git pull origin main 第二步:新建并切换分支 不要在 …

作者头像 李华
网站建设 2026/4/1 4:18:12

智能安防(有完整资料)

资料查找方式:特纳斯电子(电子校园网):搜索下面编号即可编号:CP-51-2021-051设计简介:本设计是基于单片机的智能安防系统,主要实现以下功能:可通过LCD1602安防状态和是否有人&#x…

作者头像 李华
网站建设 2026/3/27 10:13:53

django基于大数据旅游数据分析与推荐系统的设计与实现

前言Django基于大数据的旅游数据分析与推荐系统是一个结合了Python编程语言、Django Web框架、大数据技术以及推荐算法的综合性平台,旨在通过收集、分析和利用旅游相关的数据,为用户提供个性化的旅游推荐服务,同时为旅游企业和管理部门提供决…

作者头像 李华
网站建设 2026/3/31 8:15:53

SSH登录异常频发:除了改端口,我们还能做什么?

封不完的IP?拦不住的爆破?这四招让黑客直接绝望! 各位运维工程师、系统管理员,上面这些吐槽,是不是你们的日常?面对SSH暴||力破解,修改默认22端口就像是给家门换了一把没藏在垫子底下、但藏在花…

作者头像 李华