基于gitlab的项目管理流程
框架
背景
个人是不太愿意使用用户体验差的软件来做项目管理,行业内,要找到这么一款软件,又要符合自己的需求,着实不容易。要免费,易用性要好,要安全,要有数据统计。而程序员的世界,SVN 之后,可能没有人会拒绝 github,gitlab。从开发的角度出发,基于此平台作自我迭代和研发,则应当是最接地气,最容易推广的事情。
从代码开始迁移到 gitlab 到最终完成项目流程的改造,花费了大概两年时间。中间经历了,BUG管理系统的迁移,测试流程的迁移,进而影响到产品流程的迁移。后续又完善了文档管理,存储,pipline的CICD的自我构建。打通了项目流程的同时,也完成了 DevOps 的使命。

团队内部项目管理有三大默契(原则):
- 一切是在线协同的
- 一切内容是透明的
- 一切行为是自主的
1. 项目管理
- 敏捷管理
- 看板管理:Backlog -> to do -> doing -> close
- 燃尽图:plan -> burning -> prediction -> addition
- 进度:项目进度、进度监控
- 报告:日报、周报
- 评价:项目评价、个人评价
- 状态:milestone、label
- issue:可关联、状态同步、闭环
- 任务交接流程管理

用此作项目管理,主要围绕以下几点来作改进。
- 按照上面的原则第3点,我们所有任务安排妥当后,每个人任务都是由具体的执行人来评估、添加、移动。PM 只承担指导、监控、收集问题、并改进的责任。
- 解放写周报的政治性任务:只要任务规划好,并每天自行拖动任务,报表自动生成。
关于燃尽图的指引,由另外的文章给出。
2. 权限管理
- 权限分组
- 防止外泄,
只有在公司内网才能访问
3. 存储管理
- docker 镜像
- 文件存储:图、文件(rar/word/excel/pdf etc.)、视频
- 其他
4. 文档管理系统
- 在线协作
- 模板管理
- markdown
- PPT
- 甘特图
- yaml
- WIKI
- 文档中心:接口、方案、总结
5. 需求管理
- 需求原稿
- 需求指派、受理
- 需求讨论、变更
- 需求跟进
6. 开发管理
- 代码托管
- 分支管理
- 版本管理 -> tag
- static code-review
- UT/UT coverage
- gomock
- build
- CI
7. 质量管理
- 提测需求&进度管理
- BUG管理:bug分类、等级
- 用例管理
- 用例审核
使用 gitlab 作 bug 管理,采用 label 进行 bug 标记和分类,分类包括了 bug 等级、bug 的质量高低等信息。标签可以用脚本统一增删查改。
bug 跟随项目 project 而走,便于回溯。我们的要求是:任何一次代码提交是可溯源的。 是因为 bug 修复还是需求更新而更新代码,merge 时,必须能够 mention 到具体的 issue。根据需求版本建立 milestone,并且将 bug 归属于 milestone 中,心作质量管理和分析。
bug 是跨项目存在的,例如我们有100多个project,是不利于 bug 管理的。于是写了一个调用 API 的脚本,定时和手动将 bug 导出为 excel 用于分析。
单元测试,mock测试用例能够更好的与被测代码融合,即便开发线上修改,也能够将测试代码在线上运行。
8. 上线管理
- pipeline:CD
- 与 TDC DevOps 关联
- 上线 issue
- 运维可参与
9. 日志管理
- history
- comments
- status
- changes
10. 消息通知
- todo lists
- email push
- 钉钉
优缺点
| 项 | 优点 | 缺点 |
|---|---|---|
| 统一平台 | 无系统切换成本资源复用权限统一管理 | 二次开发需开发维护 |
| 项目管理 | 敏捷管理自研个性化定制需求开发测试有独立池管理 | 对于项目管理资源融合要求更高 |
| issue | 囊括产品需求、提测需求bug、上线、方案讨论 | 需要统一整理,否则不便于查找 |
| BUG提交 | 与项目相关联,利于追踪溯源BUG重现可提交视频 | 不便于统计,需跑自研脚本定时下拉 |
| 维护 | 公司级团队维护备份无需额外投入人力全面日志管理与历史记录 | 无 |
| 安全 | 离职人员带不走资料不需要查邮件回顾 | 公司外无法访问但可事先pull到本地 |
6人点赞
作者:钟沐
链接:https://www.jianshu.com/p/4a9b8764599e
来源:简书
基于gitlab的项目管理流程的更多相关文章
- 基于Gitlab的CICD流程
本片文章主要初步介绍什么是CICD流程,并且把整个流程进行拆分理解整个流程的跑通过程. 1.CICD概述 什么是CICD呢? 简单的说CICD就是持续集成自动构建自动测试自动部署. 从概念上就可以看出 ...
- 基于SpringBoot的项目管理后台
代码地址如下:http://www.demodashi.com/demo/13943.html 一.项目简介 在使用本项目之前,需要对SpringBoot,freemaker,layui,flyway ...
- 为某金融企业的IT技术部人员提供基于TFS的软件研发流程介绍
受莫金融企业IT信息技术部的邀请,为该金融企业的某省分公司.地市分公司的IT技术人员提供了一场基于TFS的软件研发流程的技术培训,希望可以借此提高该企业的软件研发.运维水平,同时推动企业软件研发信息化 ...
- 基于GitLab CI搭建Golang自动构建环境
基于GitLab CI搭建Golang自动构建环境 Golang发布遇到的问题 对于golang的发布,之前一直没有一套规范的发布流程,来看看之前发布流程: 方案一 开发者本地环境需要将环境变量文件改 ...
- 部署基于Gitlab+Docker+Rancher+Harbor的前端项目这一篇就够了
部署基于Gitlab+Docker+Rancher+Harbor的前端项目这一篇就够了 安大虎 momenta 中台开发工程师 6 人赞同了该文章 就目前的形势看,一家公司的运维体系不承载在 Do ...
- 大揭秘| 我司项目组Gitlab Flow && DevOps流程
长话短说,本文全景呈现我司项目组gitlab flow && devops Git Flow定义了一个项目发布的分支模型,为管理具有预定发布周期的大型项目提供了一个健壮的框架. Dev ...
- 基于SVN的项目管理——集中与分散
我们在此处不讨论 GIT 比 SVN 好多少,也不讨论 Maven 和 Gradle 哪个好用,基于现有的开发环境,大多数公司还是采用 SVN + Maven 来进行项目管理——因为这已经满足了大多数 ...
- 基于web的项目管理软件Redmine
Redmine是用Ruby开发的基于web的项目管理软件,是用ROR框架开发的一套跨平台项目管理系统,据说是源于Basecamp的ror版而来, 支持多种数据库,有不少自己独特的功能,例如提供wiki ...
- 基于GitLab的Code Review教程
一.前言 1.本文主要内容 GitLab Code Review机制说明 Git Workflow 与 Git Code Review Workflow GitLab Code Review 配置说明 ...
随机推荐
- c++ DWORD和uintptr_t
x86模式 DWORD 是4字节 x86模式 uintptr_t 是4字节 x64模式 DWORD 是4字节 x64模式 uintptr_t 是8字节 std::cout << sizeo ...
- Linux零拷贝技术
本文转载自Linux零拷贝技术 导语 本文讲解 Linux 的零拷贝技术,云计算是一门很庞大的技术学科,融合了很多技术,Linux 算是比较基础的技术,所以,学好 Linux 对于云计算的学习会有比较 ...
- 为什么Linux需要虚拟内存
本文转载自为什么 Linux 需要虚拟内存 导语 操作系统中的 CPU 和主内存(Main memory)都是稀缺资源,所有运行在当前操作系统的进程会共享系统中的 CPU 和内存资源,操作系统会使用 ...
- 在.NET中使用Apache Kafka(一)
曾经在你的应用程序中使用过异步处理吗?在处理不需要立即执行的任务时,异步代码似乎是不可避免的.Apache Kafka是最常用和最健壮的开源事件流平台之一.许多公司和开发者利用它的强大功能来创建高性 ...
- c++类的简介
一 类的定义 在c++中,我们使用"类"来描述"对象",可以说"类"的实现是c++OOP的核心. 类中包括对象的"属性" ...
- HDOJ-3065(AC自动机+每个模板串的出现次数)
病毒侵袭持续中 HDOJ-3065 第一个需要注意的是树节点的个数也就是tree的第一维需要的空间是多少:模板串的个数*最长模板串的长度 一开始我的答案总时WA,原因是我的方法一开始不是这样做的,我是 ...
- CVE-2014-4210 SSRF漏洞
Weblogic中存在一个SSRF漏洞,利用该漏洞可以发送任意HTTP请求,进而攻击内网中redis.fastcgi等脆弱组件. 修复方式: 1.删除server/lib/uddiexplorer.w ...
- 面试被吊打系列 - Redis原理
小张兴冲冲去面试,结果被面试官吊打! 小张: 面试官,你好.我是来参加面试的. 面试官: 你好,小张.我看了你的简历,熟练掌握Redis,那么我就随便问你几个Redis相关的问题吧.首先我的问题是,R ...
- MySQL深入研究--学习总结(4)
前言 接上文,继续学习后续章节.细心的同学已经发现,我整理的并不一定是作者讲的内容,更多是结合自己的理解,加以阐述,所以建议结合原文一起理解. 第13章<为什么表数据删除一般,表文件大小不变?& ...
- 测试工程师Docker基础
一.docker概述 1.docker为什么会出现 本质:所有技术的出现都是因为出现了一些问题,我们需要去解决,才去研究和学习: 问题: 开发环境.测试环境.仿真环境.正式环境等诸多环境都需要进行 ...