图解 Git 工作流:理解 Rebase、Merge 与 Pull Request 的区别

图解 Git 工作流:理解 Rebase、Merge 与 Pull Request 的区别

在多人协作开发中,选择合适的 Git 分支管理策略至关重要。Merge、Rebase 和 Pull Request 是最常见的三种方式,它们本质不同,使用场景也不同。

本文将通过流程图(使用 Mermaid 格式)来详细解释三者的工作机制、优劣对比和最佳实践。


一、Merge 工作流图:保留分支结构

main 分支提交 A
提交 B
feature 分支提交 C
提交 D
main 分支继续提交 E
执行 merge 操作
生成 merge commit

✅ 特点

  • 保留所有分支和提交历史
  • 清晰展现开发流程
  • 会创建一个合并提交(merge commit)

二、Rebase 工作流图:线性提交历史

main 分支
提交 B
feature 分支提交 C
提交 D
main 分支继续提交 E
执行 rebase 操作
feature 分支提交 C'
feature 分支提交 D'

✅ 特点

  • 提交历史线性、整洁
  • 修改了提交哈希
  • 不适合公共分支使用

三、Pull Request 流程图:代码审查与协作

graph LR
A[main 分支:提交 A] --> B[提交 B]
B --> C1[feature 分支:提交 C]
C1 --> C2[提交 D]
B --> D[main 分支继续提交 E]
C2 --> E1{发起 Pull Request}
D --> E1
E1 --> F[代码审查/CI 检查]
F --> G{选择合并方式}
G --> H[merge 或 rebase 方式合并进 main]

✅ 特点

  • 跨团队协作首选
  • 可配置 CI、审批流程
  • 最终由项目管理员决定合并方式

四、三者对比表

功能/特性MergeRebasePull Request
历史结构分叉结构,保留所有分支线性历史,清晰整洁可选择 merge 或 rebase
是否生成新提交✅ 合并提交❌ 不生成额外提交✅ 可生成(取决于合并策略)
是否更改提交哈希❌ 保留原提交✅ 会重写提交历史❌ 默认为保留
推荐使用场景多人协作、需保留开发分支记录个人开发、整理历史团队协作、审核流程

五、最佳实践建议

  • ✅ 本地个人开发可使用 rebase,提交更整洁
  • ✅ 推送远程协作开发建议使用 merge
  • ✅ 所有特性分支合并到主分支前应通过 Pull Request
  • ⚠️ 不要对公共分支执行 rebase,会导致历史冲突

六、总结

不同的 Git 工作流方式适用于不同的团队与开发阶段:

  • Merge 更加保守、安全
  • Rebase 更整洁、高效
  • Pull Request 更适合团队协作与代码审查

灵活选择,才能发挥 Git 的最大威力。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/79516.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Dart和Go语言特征对比

文章目录 Dart 和 Go 语法对照表字符串常用方法对照列表(数组/切片)常用方法对照Map (字典/哈希表) 使用对照IO 操作对照文件操作标准输入输出网络IO 主要差异说明 有同事说,我前端用Flutter,后端用Golang,都师出名门。但两个语言还是老打架&…

ActiveMQ 集群搭建与高可用方案设计(二)

五、高可用方案设计与优化 (一)Zookeeper 在 ActiveMQ 集群中的应用 作用:在 ActiveMQ 集群中,Zookeeper 扮演着至关重要的角色。它主要用于选举 Master 节点,通过其内部的选举机制,从众多的 ActiveMQ Br…

【项目归档】数据抓取+GenAI+数据分析

年后这两个月频繁组织架构变动,所以博客很久没更新。现在暂时算是尘埃落定,趁这段时间整理一下。 入职九个月,自己参与的项目有4个,负责前后端开发,测试,devops(全栈/doge)&#xff…

服务器热备份,服务器热备份的方法有哪些?

服务器热备份是保障业务连续性的重要技术手段,通过实时数据同步和快速故障切换,确保在主服务器故障时备份服务器能无缝接管。以下是常见的服务器热备份方法及其核心要点: 双机热备(Active-Standby/Active-Active) 主备…

【AI平台】n8n入门6:调用MCP服务(非社区节点)

前言 前边用n8n搭建一个MCP服务,现在,用n8n调用其他服务商提供的MCP服务。本文以高德地图服务为例,记录一下操作过程。 实现案例功能 MCP是啥 MCP(Model Context Protocol,模型上下文协议)是由Anthropi…

基于ArduinoIDE的任意型号单片机 + GPS北斗BDS卫星定位

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言1.1 器件选择1.2 接线方案 二、驱动实现2.1 核心代码解析(arduino/ESP32-S3) 三、坐标解析代码四、典型问题排查总结 前言 北斗卫星导航…

经典算法 最小生成树(prim算法)

最小生成树 题目描述 给定一个 n 个点 m 条边的无向图,图中可能存在重边和自环,边权可能为负数。 求最小生成树的树边权重之和。如果最小生成树不存在,则输出 impossible。 给定一张边带权的无向图 G (V, E),其中&#xff1a…

LeetCode算法题 (设计链表)Day16!!!C/C++

https://leetcode.cn/problems/design-linked-list/description/ 一、题目分析 你可以选择使用单链表或者双链表,设计并实现自己的链表。 单链表中的节点应该具备两个属性:val 和 next 。val 是当前节点的值,next 是指向下一个节点的指针/引…

《解锁GCC版本升级:开启编程新世界大门》

《解锁GCC版本升级:开启编程新世界大门》 一、引言:GCC 版本升级的魔法钥匙 在编程的广阔天地里,GCC(GNU Compiler Collection)宛如一座灯塔,为无数开发者照亮前行的道路。它是一款开源且功能强大的编译器集合,支持 C、C++、Objective - C、Fortran、Ada 等多种编程语言…

toLua笔记

基本 LuaState luaStatenew LuaState(); luaState.Start(); luaState.DoString("xxx"); luaState.DoFile("yyy.lua"); luaState.Require("zzz");//不要加.lua后缀 luaState.CheckTop();//检查解析器栈顶为空 luaState.Dispose(); luaStatenull;…

go实现双向链表

需求 实现双向链表的节点生成、正反向遍历、指定删除。 实现 package mainimport ("fmt" )type zodiac_sign struct {number intdizhi stringanimal stringyear intprevious *zodiac_signnext *zodiac_sign }// 添加 // func add_node_by_order(pr…

AI实践指南:AGENT、RAG和MCP在Java中的简单实现

在当今AI快速发展的时代,有几个核心概念正在改变我们构建智能应用的方式。本文将用简单易懂的语言介绍三个重要概念:AGENT(AI代理)、RAG(检索增强生成)和MCP(多通道感知)&#xff0c…

解决VMware虚拟机能搜索到网页但打不开的问题

🌴 问题描述 很奇怪,不知道为什么,我安装的Windows 10虚拟机能在浏览器中搜索到网页,但点击具体的网页链接就是死活不能加载出来,如下图所示: 点击第一个链接,加载了四五分钟,结果就…

JVM性能调优的基础知识 | JVM内部优化与运行时优化

目录 JVM内部的优化逻辑 JVM的执行引擎 解释执行器 即时编译器 JVM采用哪种方式? 即时编译器类型 JVM的分层编译5大级别: 分层编译级别: 热点代码: 如何找到热点代码? java两大计数器: OSR 编译…

什么是多租户系统

随着云计算和 SaaS(Software as a Service)模式的普及,多租户架构(Multi-Tenant Architecture)成为 SaaS 产品设计中的核心模式之一。多租户架构允许多个用户(租户)共享同一套基础设施和应用&am…

多线程系列三:这就是线程的状态?

1.认识线程的状态 NEW:Thread对象已经创建好了,但还没有调用start方法在系统中创建线程 RUNNABLE:就绪状态,表示这个线程正在CPU上执行,或准备就绪,随时可以去CPU上执行 BLOCKED:表示由于锁竞争…

【C语言练习】019. 使用结构体数组存储复杂数据

019. 使用结构体数组存储复杂数据 019. 使用结构体数组存储复杂数据示例1:定义一个结构体并创建结构体数组定义结构体创建并初始化结构体数组输出结果 示例2:动态输入数据到结构体数组定义结构体动态输入数据示例输入和输出 示例3:使用结构体…

**Java面试大冒险:谢飞机的幽默与技术碰撞记**

互联网大厂Java求职者面试:一场严肃与搞笑交织的技术盛宴 场景: 互联网大厂面试间 人物: 面试官: 一位严肃的资深架构师,对技术要求严格。谢飞机: 一位搞笑的程序员,技术实力参差不齐。 第一…

MySQL进阶(三)

五、锁 1. 概述 锁是计算机协调多个进程或线程并发访问某一资源的机制(避免争抢)。 在数据库中,除传统的计算资源(如 CPU、RAM、I/O 等)的争用以外,数据也是一种供许多用户共享的资源。如何保证数据并发…

【BLE】【nRF Connect】 精讲nRF Connect自动化测试套件(宏录制、XML脚本)

目录 前言 1. nRF Connect自动化测试介绍 1.1. nRF connect宏录制功能介绍 1.2. 电脑端XML方式 1.3 实际应用案例 1.3.1 BLE 稳定性测试 1.3.2 设备固件更新(DFU)测试 1.3.3 批量设备配置 1.4 操作步骤 1.5 注意事项 2. nRF Connect日志记录 2.1. 日志记录功能 …