参考GIT版本管理:Git Flow模型,在此基础上加入了自己的理解,增加人员分工和相应代码,并根据本次项目的实际情况进行相应修改。

在本学期的软件工程开发过程中,我们从alpha阶段就使用了git flow模型进行git代码版本管理。鉴于我们的开发团队存在开发人数较少(7人)、任务周期固定(一次任务持续半周/一周)、成员各自任务之间关联性小、无需在版本发布前完成全面测试的特点,将传统的git flow模型进行了简化和实践。

本篇博客讲解我们使用的简化git flow模型,并提供了我们用到的所有指令代码,希望能给大家的开发带来帮助。本文不再去讲解最基础的代码提交、分支切换原理和流程。有任何错误或者疑问,可以在评论区指出和讨论~

完整git flow模型如图:

人员职责

开发者:所有人员都为开发者,可以对代码进行修改和提交。但开发者只允许从develop分支拉取个人feature分支后修改,commit后merge到develop中,而不允许直接改动develop分支,更不允许对master分支有任何操作

版本管理者:本团队有1名版本管理者,负责在一次任务周期的最后阶段,所有人的提交全部merge到develop后,对master分支的相关操作,以更新master分支。

分支概述

远程分支

master:只有版本管理者有权利进行操作。简单地说,master上的每个版本都应该是相对稳定的版本,是每一次所有开发者的开发任务结束后留档的版本。

develop:每个开发者都可以从develop分支上拉取新分支,开发完成后合并到develop分支。

本地分支

master:连接远程master分支。

develop:连接远程develop分支。

feature:在一个任务周期中,从develop拉取,进行修改和提交。完成该周期的个人任务后,合并到develop分支,并将本地的feature分支删除。feature分支不允许提交到远程,即不允许在feature分支中出现push操作。feature分支以开发者名字简写命名。

release:在一个任务周期的最后阶段,所有人的提交全部merge到develop后,从develop分支拉取release分支,进行一定的测试。测试结束后合并到master和develop分支,并删除本地release分支。release分支以'release-x.x'命名,如‘release-0.9’,‘release-0.10’,‘release-1.0’等。release分支不允许提交到远程

一些约定

在每次add指令前,通过git branch查看分支是否正确。在每次git add .前,通过git status查看修改的文件。

具体操作

开发者

在一周的开发任务分配后,从develop创建自己的feature分支,以姓名简写命名:

任意分支下git checkout -b yourname develop

完成一部分开发任务后,提交代码:

git add filename
git commit -m "what have you changed"

注意并不push,即该分支只出现在本地。

重复上条,直到本次个人任务完成。提交到develop中:

git checkout develop
git pull origin develop # 拉取远程develop代码到最新版本,防止merge出现冲突
git merge --no-ff yourname # --no-ff不使用fast-forward方式合并,保留分支的commit历史
git push origin develop

删除本地feature分支:

git branch -d yourname

分支管理者

在该任务周期结束,所有人都merge到develop分支后,创建release分支,以'release-x.x'命名:

任意分支下git checkout -b release-0.1 develop

进行简单测试后,如果出现bug,在release分支下修改,提交:

git add filename
git commit -m "what have you changed"

将release分支合并到master分支:

git checkout master
git merge --no-ff release-0.1
git tag 0.1 # 对正式版本打tag

如果在release上修改过代码,还要合并到develop分支:

git checkout develop
git merge --no-ff release-0.1

将tag推送到远程,并将master更新:

git push --tags
git push

删除本地release分支:

git branch -d release-0.1

对git flow的简化和实践中的问题

采用git flow后的git network如图:

  • 简化hotfix分支:hotfix分支用于在master出现bug后紧急修复。因为我们项目的迭代较快,用户较少,衡量新建hotfix分支的复杂程度,暂时删去。但在更大规模的项目中,hotfix很值得使用。

  • git flow的优点:远程只有master和develop两个分支,且除版本管理者外他人无权修改master代码,保证出现问题时,进行修复工作的目的清晰。

  • 对测试人员的不友好:理论上,release分支的作用包括了对即将发布版本的测试。但是可以发现,此处的release分支仅仅为本地分支,即版本管理者在将develop分支发布到master分支的过程中,测试人员是无法切换到release分支的。这一点对测试人员并不友好。但在我们的项目中,反而比较合适。由于项目属于课程设计,且不具有盈利性,要求测试人员在版本上线当晚必须投入到测试工作并不合理。通过衡量等待测试完成的时长和上线后出现bug的严重性,我们决定采用目前的分支管理方法,即在分支管理人员在release分支运行自动化测试工具进行功能测试后,发布到master分支。测试人员在之后的几天里,对项目新增代码进行代码级别的测试。

  • 对开发结束后再次修改代码的不友好:可以发现,在结束自己本周期的开发任务,删除本地feature分支后,如果再次发现自己的修改存在bug,仍然需要重新拉取feature分支,这是一个比较繁琐的过程。我们也发现了存在部分成员在此时会直接进入develop分支修改代码。

  • git branchgit status至关重要:提交错了分支和文件引发的版本回滚比较繁琐,因此提交前一定注意,要对自己的提交动作负责。

【技术博客】Git Flow模型管理代码版本的更多相关文章

  1. [技术博客]React Native——HTML页面代码高亮&数学公式解析

    问题起源 原有博文显示时代码无法高亮,白底黑字的视觉效果不好. 原有博文中无法解析数学公式,导致页面会直接显示数学公式源码. 为了解决这两个问题,尝试了一些方法,最终利用开源类库实现了页面美化. (失 ...

  2. 【转】Git连接oschina管理代码版本

    原文网址:http://blog.csdn.net/liukang325/article/details/24051467 工作中一般都是用的SVN,最近好像GitHub有些火,看到开源中国上也有Gi ...

  3. 全流程指导Visual Studio Code+Markdown Nice+gitee+PicGo管理自己的技术博客文章

    全流程指导Visual Studio Code+Markdown Nice+gitee+PicGo管理自己的技术博客 1.背景 我挺喜欢写博客,但每一次将博客转移到公众号或者知乎,总是需要调整格式,不 ...

  4. 创建GitHub技术博客

    创建GitHub技术博客全攻略 githubio技术博客网站生成 说明: 首先,你需要注册一个 github 账号,最好取一个有意义的名字,比如姓名全拼,昵称全拼,如果被占用,可以加上有意义的数字.本 ...

  5. Git Flow 分支管理简述

    概述 Git 是什么 Git 是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目. Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的 ...

  6. 创建GitHub技术博客全攻略【转】

    本文转载自:http://blog.csdn.net/renfufei/article/details/37725057/ 说明: 首先,你需要注册一个 github 账号,最好取一个有意义的名字,比 ...

  7. 技术人如何利用 github+Jekyll ,搭建一个独立免费的技术博客

    上次有人留言说,技术博客是程序员的标配,但据我所知绝大部分技术同学到现在仍然没有自己的技术博客.原因有很多,有的是懒的写,有的是怕写不好,还有的是一直想憋个大招,幻想做到完美再发出来,结果一直胎死腹中 ...

  8. [技术博客] 软工-Ruby on Rails 后端开发总结分享

    [技术博客] 软工-Ruby on Rails 后端开发总结分享 在这次软件编写中,我们的后端使用了Ruby on Rails (RoR)框架. Rails框架是用Ruby编写的.这意味着当我们为Ru ...

  9. 【转】【技术博客】Spark性能优化指南——高级篇

    http://mp.weixin.qq.com/s?__biz=MjM5NjQ5MTI5OA==&mid=2651745207&idx=1&sn=3d70d59cede236e ...

随机推荐

  1. jQuery选择器与过滤器(二)

    一.jQuery选择器1.基本选择器:所有选择器    *标签选择器    标签名ID选择器    #ID类选择器    .className组合选择器    selector1,selector2 ...

  2. 面试题:什么叫平衡二叉查找树--AVL树

    查找.插入和删除在平均和最坏情况下都是O(log n) 增加和删除可能需要通过一次或多次树旋转来重新平衡这个树 节点的平衡因子是它的左子树的高度减去它的右子树的高度.带有平衡因子 1.0 或 -1 的 ...

  3. Shell 冒泡排序

    举例 #!/bin/bash echo "please input a number list:" read -a arrs for((i=0;i<${#arrs[@]};i ...

  4. Python 列表推导式、矩阵、格式化输出

    列表推导式 列表推导式提供了从列表.元组创建列表的简单途径.语法: [表达式 for语句 if语句] 创建并返回一个列表.if语句可选. 示例: list1=[1,2,3,4] #使用元组也行 lis ...

  5. SpringBoot+Jpa+SpringSecurity+Redis+Vue的前后端分离开源系统

    项目简介: eladmin基于 Spring Boot 2.1.0 . Jpa. Spring Security.redis.Vue的前后端分离的后台管理系统,项目采用分模块开发方式, 权限控制采用 ...

  6. VUE 动态菜单管理

    业务场景 不同的用户登录,看到的菜单会不一样,因此需要根据不同人登录的身份去后端获取菜单. 实现思路 1.构建路由 2.从后端构建菜单 3.前端获取菜单 4.前端渲染菜单 1.构建路由. export ...

  7. nginx.从路人到入门

    nginx 提供各种各样的服务器功能,本文记录 nginx 最基础的操作: 开启.停止.重载配置 静态文件服务器 反向代理 本文操作系统环境为 ubuntu18 安装 官方安装指导 开启.停止.重载配 ...

  8. PAT 乙级 1023.组个最小数 C++/Java

    题目来源 给定数字 0-9 各若干个.你可以以任意顺序排列这些数字,但必须全部使用.目标是使得最后得到的数尽可能小(注意 0 不能做首位).例如:给定两个 0,两个 1,三个 5,一个 8,我们得到的 ...

  9. 一个兼容IE7\IE8,H5的多功能视频播放器,H5视频播放器兼容Flash视频播放器

    这里记录一个视频播放器,免费可适当修改:名称:ckplayer视频播放器(免费) 官网地址:http://www.ckplayer.com/ 下载地址:http://www.ckplayer.com/ ...

  10. Java批量下载文件并zip打包

    客户需求:列表勾选需要的信息,点击批量下载文件的功能.这里分享下我们系统的解决方案:先生成要下载的文件,然后将其进行压缩,生成zip压缩文件,然后使用浏览器的下载功能即可完成批量下载的需求.以下是zi ...