Git工作流程

Git工作流程

  • 分类

    • Git flow
    • Github flow
    • Gitlab flow
  • 共同点:

    功能驱动:需求是开发的起点,先有需求再有功能分支(feature branch)或者补丁分支(hotfix branch)。完成开发后,该分支就合并到主分支,然后被删除。

Git flow

项目存在2个长期分支:

  • 主分支master[存放对外发布的版本]
  • 开发分支develop[日常开发的分支]

项目存在3种短期分支:

  • 功能分支(feature branch)
  • 补丁分支(hotfix branch)
  • 预发分支(release branch)

一旦完成开发,它们就会被合并进developmaster,然后被删除。

优点:

  • 清晰可控

缺点:

  • 相对复杂,需要同时维护2个长期分支。大多数工具都将master当作默认分支,可开发在develop分支,导致要经常切换分支。
  • 基于版本发布,目标是一段时间的产出一个新版本。如果是持续发布的项目,代码一有变动,就部署一次。这时masterdevelop分支差别不大,没必要维护2个长期分支。

Github flow

Github flow是git flow的简化版,用于持续发布

只有1个长期分支master,用起来非常简单。

官方推荐流程:

第一步:根据需求,从master拉出新分支,不区分功能分支或补丁分支。

第二步:新分支开发完成后,或者需要讨论的时候,就向master发起一个pull request(简称PR)。

第三步:Pull Request既是一个通知,让别人注意到你的请求,又是一种对话机制,大家一起评审和讨论你的代码。对话过程中,你还可以不断提交代码。

第四步:一旦你的Pull Request通过评审,并通过测试,就可以部署在生产上,如果出现问题,可以用现有的master分支代码进行回退。

第四步:如果部署在生产上的代码没有问题,那么你的Pull Request将被接受,合并进master。一旦合并(merge),Pull Request就会生成一条commit记录,方便以后搜索与查找。

优点:

  • 简单
  • 适用于持续发布的产品

缺点:

  • master分支的更新必须与产品的发布一致。但有时候代码合并进master,并不代码它能立刻发布。比如苹果APP审核要时间,或者有些公司有发布窗口。导致线上版本落后于master分支。此时,需要新建一个production分支跟踪线上版本。

Gitlab flow

Gitlab flow 是 Git flow 与 Github flow 的综合。它吸取了两者的优点,既有适应不同开发环境的弹性,又有单一主分支的简单和便利。它是 Gitlab.com 推荐的做法。

上游优先upsteam first

  • 即存在一个主分支master,它是所有其他分支的上游。只有上游分支采纳的代码变化,才能应用到其他分支。

持续发布:

  • master分支:开发环境
  • pre-production分支:预发环境
  • production分支:生产环境

开发分支是预发分支的”上游”,预发分支又是生产分支的”上游”。代码的变化,必须由”上游”向”下游”发展。比如,生产环境出现了bug,这时就要新建一个功能分支,先把它合并到master,确认没有问题,再cherry-pickpre-production,这一步也没有问题,才进入production

只有紧急情况,才允许跳过上游,直接合并到下游分支。

版本发布:

  • master分支:主分支
  • 2-3-stable分支:稳定版本分支

只有修补bug,才允许将代码合并到这些分支,并且此时要更新小版本号(通过打tag方式)。

个人开发

建议Gitlab flow

0%