【gitflow】 概念基本介绍

这篇具有很好参考价值的文章主要介绍了【gitflow】 概念基本介绍。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

gitflow

简介

什么是gitflow?

我们大家都很会用git,但是我们很少去关心我们要怎么用branch和版本控制。

只知道master是第一个主分支,其他分支都是次要分支, 那你知道如下的问题如何回答吗?

  • 如何保证主分支的稳定性?
  • 如何开发新的feature?
  • 如何创建分支名称?分支多了如何管理?如何知道每个分支干嘛的呢?
  • 哪些分支合并了?
  • 哪些分支是release的分支?可以稳定使用的?
  • 如果稳定分支代码出现没有测出来的bug,如何创建分支快速修复?

这个就像写代码,要有个规范一样, 当然我们可以不按照规范来做,git同样能处理。但是定义一个科学的操作规范,往往能让效率事半功倍。

创始人的分享链接:

https://nvie.com/posts/a-successful-git-branching-model/

gitflow 是一种git分支模型,是由创始人Vincent Driessen 2010年创建的。这只是一种建议,在团队合作中,具体项目中要灵活应用,不用可守成规,觉得不合理的地方可以自行修正。

gitflow 流程图

我们来看下创始人最初的流程图:

gitflow,git,github

我们来换个角度来理解

gitflow,git,github

gitflow的核心要素是branch,通过branch来实现工作流。

主要分为两大类:

  • 主分支(Main Branches)
  • 辅助分支(supporting branches)

拓展开来:

主分支: Master Develop

辅助分支:Feature、Release、Hotfix

gitflow工作流如何使用

刚开始的时候,我们有个master分支,我们要基于master来创建develop

gitflow,git,github

master

master分支上存放的是最稳定的版本,并且该分支的代码是随时可以让用户使用的代码,就是非常非常稳定的代码。当一个版本开发完成之后,交付给客户的时候,master上面的额代码也要被更新。同时,每次更新都要打上相应的tag。

任何人不允许在master上进行代码的直接push提交,只接受其他分支合入。原则上master分支必须是release的分支合过来的代码。

来源只能是:hotfix和release分支。不能是其他分支。

master一定是经过多轮测试,但是不能保证完全没有bug,所以引入hotfix分支,来修复未知bug

develop

develop是主开发分支,这个分支上被合并的代码始终是下一个版本需要加入的feature。这个分支可以合并一些feature。当要release的时候,就从这个分支上进行创建release分支。

合并到develop分支上的必须保证功能完整,不影响develop分支的正常运行。

gitflow,git,github

feature

feature 分支又叫功能分支,一般命名方法feature/xxx,用来开发版本或者未来要发布新的功能或者探索新功能。(feature 分支功能要保证里面的commit 的粒度要非常细,避免和主分支脱节严重,应该大功能切成一个一个小功能来merge,而不是一次merge一个大的)

gitflow,git,github

Release

这个分支又叫预发布分支,一般命名为 release/1.1.x 这个分支转为发布做准备。允许小量级的bug修复。

release分支只能从develop分支拉过来,用来修复一些bug。(不做feature相关的开发)

gitflow,git,github

hotfix

hotfix 叫热修复分支,一般命名为hotfix/4.1.3 为固定某个版本进行修复,当master上遇到严重问题需要修复的时候,就要从master上指定tag拉取。这样做就是为了隔离feature开发和bug修复。

hotfix只能从master上拉去,测试通过之后合并会master和develop

gitflow,git,github

总结

有些人觉得gitflow好用,有些人觉得gitflow太死板,太复杂,团队里面每个人都要遵守这套规则,会很麻烦。毕竟规则越复杂,用起来越难。所以创始人也建议团队根据实际情况调整策略。我觉得有以下几点值得注意:文章来源地址https://www.toymoban.com/news/detail-678256.html

  • 团队主要成员如果成员固定,并且训练有素,可以考虑用一下。团队人员如果太多,太杂,不建议。如果主要团队人员就1-2个人,也不建议。
  • 从时间点上来说,要将团队统一战线,比如master要开始release了,整个团队需要切到release分支去修复bug,并且坚决不允许有feature合入。大feature可以下一个版本进行合并。
  • release要全部测试人员测试完成,没有bug了,再合到master上。
  • 一定要保证master上面的有个稳定的代码源(这个是最重要的一点,如果达不到,产品化效果会很差)
  • 不同的团队保持并行开发,相互之间干扰要降到最低。

到了这里,关于【gitflow】 概念基本介绍的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 解释 Git 的基本概念

    Git是一种分布式版本控制系统,用于管理代码和其他项目文件的版本,以及协调多个开发者对同一项目的工作。以下是Git的主要概念和使用方式: 仓库(Repository):用于存储和管理项目代码和文件的地方,可以是本地仓库或远程仓库。 提交(Commit):将更改保存到Git仓库中

    2024年02月10日
    浏览(28)
  • Git基本概念

    1、git是什么:是目前世界上最先进的分布式版本控制系统 2、git的优势 ● 适合分布式开发、强调个体。 ● 公共服务器压力和数量都不会太大 ● 速度快、灵活 ● 任意两个开发者之间可以很容易的解决冲突 ● 离线工作 3、git能做什么 ● 克隆版本库(最常用的功能) ● 项目

    2024年02月07日
    浏览(21)
  • 【Git】基本概念和使用方式

    Git是一个分布式版本控制系统,用于管理和跟踪计算机文件的变化。它最初是由Linus Torvalds开发的,用于管理Linux内核的开发。 Git的基本概念包括: 仓库(Repository):一个仓库是Git中存储项目文件和历史变更的地方。它可以是本地仓库(存在于本地计算机上)或远程仓库(存

    2024年02月20日
    浏览(22)
  • RocketMQ 介绍及基本概念

    RocketMQ作为一款纯java、分布式、队列模型的开源消息中间件,支持事务消息、顺序消息、批量消息、定时消息、消息回溯等。 支持发布/订阅(Pub/Sub)和点对点(P2P)消息模型 在一个队列中可靠的先进先出(FIFO)和 严格的 顺序传递 (RocketMQ可以保证严格的消息顺序,而Ac

    2024年02月03日
    浏览(24)
  • shiro框架基本概念介绍

    Shiro 是一个强大灵活的开源安全框架,可以完全处理身份验证、授权、加密和会话管理 身份验证(Authentication):验证用户的身份,确保用户是合法的。 授权(Authorization):控制用户对系统资源的访问权限,限制用户只能访问其被授权的部分。 会话管理(Session Management):

    2024年02月13日
    浏览(27)
  • Git的基本概念和使用方式

    Git 是一个分布式版本控制系统,用于跟踪文件的变化并协调多人在同一个项目中的工作。它可以帮助团队协作开发,管理代码版本,以及追踪文件的修改历史。 Git 的基本概念包括仓库(repository)、分支(branch)、提交(commit)、合并(merge)、拉取(pull)和推送(push)。

    2024年04月27日
    浏览(26)
  • Git 的基本概念和使用方式。

    Git 是一种分布式版本控制系统,它跟踪文件的变化,允许用户在任何时间点恢复文件到之前的状态,或是比较文件之间的差异。这里是 Git 的基本概念和使用方式: 仓库(Repository):Git 仓库是用来存储项目文件和历史版本的地方。每个仓库都有一个.git目录,它包含了所有的

    2024年02月13日
    浏览(28)
  • Git 的基本概念和使用方式

    Git 是一种源代码管理工具,它可以帮助开发人员跟踪和管理代码变更,协作开发,以及管理分支和版本。 Git的基本概念包括: 版本控制:Git可以记录代码的历史版本,包括每次变更的内容、时间和作者等信息。 分支管理:Git可以创建和管理代码库中的分支,开发人员可以在

    2024年02月10日
    浏览(25)
  • ElasticSearch的介绍、安装、基本概念

            ElasticSearch是一个基于Lucene的搜索服务器。它提供了一个分布式多用户能力的全文搜索引擎,基于RESTful web接口。Elasticsearch是用Java开发的,并作为Apache许可条款下的开放源码发布,是当前流行的企业级搜索引擎。设计用于云计算中,能够达到实时搜索,稳定,可靠

    2024年02月15日
    浏览(44)
  • Git和Github的基本用法

    目录 背景 下载安装 安装 git for windows 安装 tortoise git 使用 Github 创建项目 注册账号 创建项目 下载项目到本地 Git 操作的三板斧 放入代码 三板斧第一招: git add 三板斧第二招: git commit 三板斧第三招: git push 小结 🎈个人主页:库库的里昂  🎐CSDN新晋作者  🎉欢迎 👍点赞✍评

    2024年02月10日
    浏览(27)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包