前一篇介绍了 git相关的概念,我们可以查看文件的状态,在各个状态之间进行切换,可以创建和合并分支,通过rebase还可以整理自己的提交历史。通过这些命令和操作,就可完成工作流规范规定的操作流程了。
本篇介绍具体的规范,包括分支的划分和命名规范,不同类型的分支应对不同的场景,然后会介绍下工作流工具git-flow,如何简化我们的操作。
分支构成
master和develop分支一直存在,且名称不会变化,一般不直接修改这2个分支,由其他分支合并而来。
feature、release、hotfix分别用于功能点开发、优化,特定版本测试,线上问题紧急处理,同一类型的分支会产生多个。
分支划分如下:
- master:与线上版本保持绝对一致;
- develop:开发分支,由下文提到的release、feature、hotfix分支合并过后的代码;
- feature:实际功能点开发分支,建议每个功能新建一个feature, 具有关联关系的功能公用一个feature分支;
- release:每一次开发完成之后,从develop创建出来的分支,以此分支为基准,进行测试;
- hotfix:该分支主要用于修复线上bug;
命名规范约定如下:
- feature分支命名:feature/name
- release分支命名:release/name
- hotfix分支命名:hotfix/name
比如有一个「优化分布式Session」的需求,可在develop分支的基础上创建新分支 feature/optimize_distributed_session进行开发,开发完成后合并到develop分支。
分支详细介绍和处理流程
master分支
主分支,与线上运行的版本始终保持一致,任何时候都不要直接修改master分支。
一个版本的release分支、hotfix分支开发完成后,会合并代码到master分支,也就是说master分支主要来源于release分支和hotfix分支。
develop分支
开发分支,始终保持最新完成以及bug修复后的代码,新增功能时基于该分支创建feature分支。
一个版本的release分支、hotfix分支开发完成后,也会合并到develop分支,另外,一个版本的feature功能开发完成后,也会合并到develop分支。也就是说develop分支来源于feature、release、hotfix分支。
feature分支
开发新功能或优化现有功能时,会创建feature分支,以develop为基础创建。一般会有多个功能同时开发,但上线时间可能不同,在适当的时候将特定的feature分支合并到develop分支,并创建release分支,进入测试状态。
release分支
当一组feature开发完成,会首先合并到develop分支,开始进入提测阶段时,会创建release分支。
以release分支代码为基准提测,测试过程中若存在bug需要修复,则直接由开发者在release分支修复并提交。
测试完成之后,合并release分支到master和develop分支,此时master为最新代码,用作上线。
hotfix分支
线上出现紧急问题时,需要及时修复,以master分支为基线,创建hotfix分支,修复完成后,需要合并到master分支和develop分支。
特殊情况处理和注意点
develop分支已存在未上线的feature代码, 此时需要紧急上线一个新功能, 但develop的代码不能上,如何处理 ?
- 以master为基线创建feature, 在完成之后,代码合并到master分支;
- 为了保证develop是最新代码,需要从master合并到develop分支;
以develop为基线,创建了f1和f2两个feature分支之后, f1,f2开发一半的时候,发现两个分支代码需要有依赖怎么办 ?
- 最好在开发开始前确定两个功能是否相关,若相关则只创建一个分支,两个功能在一起开发;
- 如果已经创建,则需要合并到一个分支;
一定要保证commit历史记录的整洁,代码合并时,根据情况选择merge或rebase;
使用rebase注意,一旦分支中的提交对象发布到公共仓库,就千万不要对该分支进行衍合操作;
提交说明规范:
- 提交说明最好限制在一行以内,50个字符以下,简明扼要地描述更新内容,空开一行后,再展开详细注解;
- 如果关联jira,写上jira地址;
git-flow工具
上面的流程在第一次接触时,会觉得有点复杂,通过git-flow工具可以把这些流程自动化。它是一个命令行工具,支持各个平台,比如OSX、Linux、Windows等支持。
初始化
通过 git flow init 命令进行初始化,以交互式的方式进行,主要是约定分支的命名,建议使用默认值;
开发新功能
git flow feature start f1 添加新特性,这个操作创建了一个基于develop的特性分支,并切换到这个分支之下。
git flow feature finish f1 完成新特性,这个操作会合并f1分支到develop分支,并删除特性分支,切换回develop分支。
git flow feature publish f1 发布新分支,发布新特性分支到远程服务器,其它用户也可以使用这分支。
发布版本
git flow release start r1 [BASE] 创建发布版本,[BASE]是以哪个分支或commit为基础进行发版,一般为develop。
git flow release publish r1 发布release分支,其他同事就可以看到这个分支,并修改一些小问题。
git flow release finish r1 完成release分支,会合并release分支到master分支,用release分支名打Tag,合并release分支到 develop分支,最后移除release分支。
修复线上问题
有可能需要修正 master 分支上某个 TAG 标记的生产版本。
git flow hotfix start VERSION [BASENAME] 创建hotfix分支,VERSION 参数标记着修正版本,[BASENAME]为finish release时填写的版本号。
git flow hotfix finish VERSION,当完成紧急修复分支,代码合并到develop和 master分支。相应地,master分支打上修正版本的 TAG。
欢迎扫描下方二维码,关注我的个人微信公众号 ~
相关推荐
Git分支管理规范旨在为开发团队提供一个清晰、有序的工作流程,它将代码的不同阶段(如开发、测试、发布)与相应的分支关联起来,以促进协同工作和版本控制。通过规范化的分支策略,可以避免代码冲突,保证代码质量...
### 二、Git分支规范说明 #### 2.1. Master主干 Master分支是项目的主线,始终保持可部署状态。新需求的开发不直接在Master上进行,而是从Master分支创建新分支进行开发。 #### 2.2. Developer分支 Developer...
6. 协作工作流:在团队协作中,通常采用“功能分支工作流”,每个新功能开发都在自己的分支上进行,开发完成并通过测试后,再合并到主分支。这样可以确保主分支的稳定性。 除了上述基本操作外,Git还提供了一系列...
首先,我们来看一种常见的 Git 工作流模型——git-flow。在这个模型中,有以下几个关键分支: 1. **master**:主分支,代表生产环境的稳定版本,任何时候从 master 检出的代码都应保证可发布。 2. **develop**:...
Git flow是一种常见的Git工作流模式,它定义了明确的分支策略,包括开发分支、特性分支、发布分支和热修复分支,以规范团队协作流程。 本书可能涵盖了以下关键知识点: 1. **Git基础**:安装与配置Git,创建和克隆...
OA系统(Office Automation System)的Git操作应遵循预定义的工作流,通常包括开发、测试、审查和部署等阶段。 - **开发人员日常操作规范** - **克隆分支** 开发人员应首先从远程仓库克隆主开发分支到本地,以...
在团队协作中,制定合适的Git管理规范,如合理命名分支、定期合并主分支、避免直接在master分支上工作等,有助于提高开发效率和代码质量。对于Java开发者来说,理解并熟练运用Git是日常开发必不可少的技能。
Git flow 是一种基于Git的版本控制工作流,它旨在提供一种结构化且高效的方式来管理软件项目的开发周期。这种流程特别适合大型团队协作,确保代码稳定性和版本管理的规范性。以下是一些关于如何配合Git flow流程使用...
- Git Flow:一种流行的分支模型,包括主分支、开发分支、功能分支、发布分支和修复分支,规范团队协作流程。 9. Git钩子 - 钩子脚本:在特定事件(如提交、推送等)触发前运行的自定义脚本,用于自动化检查或...
对Git flow 工作流解析与使用基本规范 Git Flow有主分支和辅助分支两类分支。其中主分支用于组织与软件开发、部署相关的活动;辅助分支组织为了解决特定的问题而进行的各种开发活动。
Git钩子是Git版本控制系统中的一个强大特性,它允许用户在特定操作执行之前或之后运行自定义脚本,以此来实现对Git工作流的定制。本文将深入探讨Git钩子的工作原理、种类以及如何利用它们优化开发流程。 一、Git...
通过利用Git钩子,开发者可以自动化一系列工作流程,如代码审核、格式检查、部署过程等,从而提高团队协作效率和代码质量。 1. **Git钩子介绍** Git钩子分为客户端钩子和服务端钩子,它们位于仓库的`.git/hooks`...
2. **Git Flow**:这是一种常用的分支管理模型,定义了明确的工作流,包括master、develop、feature、release 和 hotfix 等不同类型的分支。这种方式有助于规范团队协作和版本控制。 3. **变基(Rebase)**:是一种...
为了更好地理解和实践GitFlow工作流,下面将详细介绍其安装过程: 1. **确保Git已安装** 在安装GitFlow之前,需要确认计算机上已安装Git。如果尚未安装,请访问[Git官方网站](https://git-scm.com/downloads)下载...
- **按需工作流**:根据个人或团队的需求,选择适合的分支工作流模式。 ### 历史管理 - **错误承认与复杂情况**:面对错误,如何利用Git的历史功能追溯并纠正。 - **重写与制造历史**:探索重写历史的技术,如...
Git flow是一种广泛应用的工作流模型,它设定了Master分支作为生产环境代码的唯一源,Develop分支作为日常开发的主要分支,以及Feature、Release和Hotfix三个临时分支,用于特性开发、版本发布和紧急修复。...
- **分支**: 分支是Git中的核心概念,用于分离工作流。 - **分支的新建与合并**: 如何创建新分支、合并分支和解决合并冲突。 - **分支管理**: 如何查看、删除和重命名分支。 - **分支开发工作流**: 描述不同的团队...
- **司令官与副官工作流**:类似于集成管理员工作流,但更加灵活。 - **为项目作贡献**: - **提交指南**:规定如何提交代码的规范。 - **私有的小型团队**:针对小型团队的工作流程建议。 - **私有团队间协作**...
除了命令行工具外,还有一些第三方工具提供了更友好的图形用户界面来支持GitFlow工作流,如SourceTree等。这些工具通常具有更好的用户体验,能够更直观地展示分支之间的关系和操作历史。 ### 结语 通过以上介绍...