目前的 git
协作工作流的模式非常多,对于我们小团队而言,我们借鉴主流的 gitflow
进而构建我们的协作方式。
无论协作的方式再多,作为一个团队协作开发而言,协作必须有一个规范的工作流程。统一协作开发工作流,这样团队之间既可井然有序、高效地协作开发,同时项目开发迭代也会显得井井有条。
可知,每一个项目的一个端作为一个代码仓库,我们称之为项目单元。团队开发 与 维护主要是针对项目单元去开发、迭代甚至是维护,使用分支能够有效地避免不同开发工作之间的相关干扰。
一般而言,一个项目单元必须包括如下类型的分支:
-
master
| 主分支主分支属于线上部署的分支,是项目生产稳定运行的项目分支,该分支来自 开发分支 或 热修复分支的pull request,不能直接从其他分支进行合并。
-
develop
| 开发分支开发分支 与 主分支必须是并行的,此分支基于运行于开发环境 与 测试环境。同时,不能直接在开发分支上做开发,开发分支是由功能分支 或 修复分支合并叠成。
-
tag
| 发行标签发行分支即是项目版本可以稳定发行的版本,可看作为一个版本迭代的分水岭,譬如
1.0.0
、2.0.0
等。注意、此发行分支是基于主分支构建而来,主要用于记录版本的节点,必须基于master
分支构建。
-
feature
| 功能分支顾名思义,即功能分支,功能分支是由需求确立而成,每一个需求 或 功能就必须建立一个功能分支,好处就是各个功能独立开发则不受影响,同时团队成员之间的协作隔离不容易产生冲突。
-
hotfix
| 热修复分支热修复分支亦称为补丁分支,假设生产分支出现异常等
bug
危急的情况,需要建议一个修复分支,使得主分支合并进而解决bug
,注意、修复分支在主分支合并的同时必须由开发分支也合并,同时发行版也要合并构建成小版本的发行版,测试通过后题需要基于热修复分支打标签。
把大功能的实现尽可能分解成更多的相对独立的小模块,每个小模块测试完成后提交修改,再开始下一模块的开发。这样做能保证每次提交的内容高度相关,方便定为错误、解决合并冲突。
每次提交代码不要自以为然,必须要将改动的代码进行自测 或者 单元测试,确保开发环境 与 测试环境平稳正常运行,否则会造成持续集成不通过、程序运行失败,甚至影响团队成员之间相互开发协作。
经常提交势必让你每次提交的东西都很少,也有助于你只提交相关的改动。并且,你还能更频繁地与别人共享代码。通过这种方式,所有人在集成代码时都会感觉更轻松,也就能避免一些不必要的冲突。相比之下,如果每次提交的东西很多、改动很大、时间间隔很长,那么在代码合并过程中产生的冲突就很难解决了。约定: 在有改动的情况下,至少一天一提交。
-
主分支合并
主分支合并不能直接从其他分支合并,只能通过其他分支pull request,而且其他分支必须经过测试组测试,验收通过后达到上线标准(也就是咱们所说的封版)才能合并。一般而言、每次迭代上线前一步合并。
-
开发分支合并
开发分支合并功能分支,尽量做到**"频繁合并"**,也就是说尽量将功能需求分解成
N
个功能模块,每一个功能模块完成就提交代码并合并到开发分支,这样可以减少分支合并而造成冲突。
见《Git代码提交规范》。
如下部分命名会携带 时间、日期信息 视团队而定,目的是防止过多临时分支存在,谁的谁删除
现在已经有了版本 1.0.0 发布版本,即已经存在 tag
1.0.0 ,现在有新的版本规划 1.1.0
那么需要给予发布 1.0.0 新建一个版本开发分支
git checkout -b 1.1.0_develop
这个版本有很多不止一个功能,同时有不止一个人参与这个版本迭代开发
研发 a 需要参与视频模块开发,则需要基于 1.1.0_develop 创建一个功能分。支命名规范 feature/{version}{function}__{author}{datetime}
git checkout -b feature/1.1.0_video_a_20200806
研发 b 需要参与朋友圈模块开发,则需要基于 1.1.0_develop 创建一个功能分
git checkout -b feature/1.1.0_friends_group_b_20200805
切记千万不要在开发分支直接提交代码 开发分支是合并分支
开发完毕合并功能分支,处于不断合并的过程
git merge feature/1.1.0_video_a_20200806
git merge feature/1.1.0_friends_group_b_20200805
自测完成后,没有问题那就将功能分支删除
git branch -d feature/1.1.0_video_a_20200806
git branch -d feature/1.1.0_friends_group_b_20200805
提测发现有缺陷,需要基于版本迭代分支创建缺陷修复分支
git checkout -b fix/1.1.0_video_upload_bug_yibing_20210601
修复完成再合并到迭代分支
git merge fix/1.1.0_video_upload_bug_yibing_20210601
测试通过后 通过约定的方式 tag
即为发布版本 发布 1.1.0 版本
git tag -a 1.1.0 -m "release:version:1.1.0"
线上发现缺陷后 仓库操作与协作约定
基于主版本分支新建热修复分支
热修复分支测试完成后pull request主分支
基于主分支新建新的版本标签
开发分支合并热修复分支
务必在
git
上编写更新内容