作为软件行业的从业者对Jira的概念都不会太陌生,大家都应该在Jira上创建和操作过自己的任务。做为一个任务跟踪工具,Jira内置的workflow和管理员工具基本可以满足我们日常的工作。但是如何才能发挥出Jira的最大价值,结合企业自己的需求去挖掘Jira更高级的应用呢?我打算以一个案例,分为3期来深挖下Jira的高级应用方式。

Jira高级应用—设计篇

如何利用Jira来优化工作流程,提高工作效率

https://yejingtao.blog.csdn.net/article/details/86377882

Jira高级应用—实战篇

手把手教你如何成为合格的Jira管理员

https://yejingtao.blog.csdn.net/article/details/86586822

Jira高级应用—集成篇

如何通过调用Jira的RestfulAPI实现任务的全自动任务跟踪。

https://yejingtao.blog.csdn.net/article/details/87479490

Jira高级应用—扫雷篇

使用过成功发现的Jira的一些缺陷

https://yejingtao.blog.csdn.net/article/details/87997524

我们公司对Jira依赖程度还是很高的,基本每天一两千人在线使用,对于Jira的定位基本就是任务跟踪,依靠Jira的工作流完成任务的分发。我现在想做的是通过jira将软件的发布全生命周期管理起来,从研发提交git的tag到应用上线后的运行情况,统一由Jira做为数据中心和控制中心,将涉及到的所有人员串联起来,一起高效的完成发布任务。

第一步:根据企业自己的特色梳理标准的发布流程

这是我梳理出来的应用发布workflow

环节及相关人员:

0 发起申请(研发负责人)

研发决定要更新某个应用的版本,在git上提交tag。

1 等待构建(Jenkins自动构建)

Git触发Jenkins的任务对本次软件包进行编译

2 环境部署(业务运维)

云平台上启动一个实例,将新版本的软件包部署上去,并准备好运行环境。

3 测试验证(测试负责人)

对新版本的功能进行验证,对老功能进行回归。

4 灰度发布(业务运维)

按很小的比例替换掉线上的服务,一般替换1-2台

5 灰度观察(测试负责人)

观察新版本1-2台机器的运行情况,一半观察1小时

6 全量发布(业务运维)

将新版本全量替换线上的老版本

7 全量观察(测试负责人)

观察线上运行情况,一般观察4-8小时。

8 上线成功(研发负责人)

研发负责人确认本次上线是否达到预期

9 故障(业务运维)

新版版在线上运行一段时间后出现故障,需要解决

10 灰度回滚(业务运维)

灰度发布或者灰度观察不通过时,需要将灰度的机器回退到老版本

11 全量回滚(业务运维)

全量发布或者全量观察不通过时,需要将所有线上机器回退到老版本

12 上线失败(研发负责人)

本次软件发布因为各种问题,没有成功。

版本相关:

git中项目名,git_tag

人员相关:

研发负责人,业务运维负责人,测试负责人

时间相关:

发起申请时间,构建完成时间,测试验证完成时间,灰度发布完成时间,灰度观察完成时间,全量发布时间,全量观察完成/上线时间,Reopne时间/故障发现时间,故障解决时间,灰度回滚完成时间,全量回滚完成时间

结束状态:

上线结果(成功,失败)

上线失败原因(构建失败,部署失败,测试失败,灰度发布失败,全量发布失败,因故障回滚, 废弃);

发起方式:

人工,系统自动

第一阶段达到的目的:

1让整个研发、运维、测试团队熟悉产品发布的workflow

2 先手动使用起来,当然设计上要求人工填写的东西越少越好,例如状态、时间点、人员转发等都需要自动完成,只需要人工点击不同的按钮决定workflow的下一步走向就好。

3 workflow运行一段时间后就会收集到各种结果和时间信息,基于这些信息就可以做统计报表,可以作为人员工作量饱和度和工作效率的考核依据。

4 可以根据报表中反馈的各环节的效率情况,决定如何对workflow进行优化。

统计参考价值

1 因编译和测试不通过导致jira任务的失败,可作为研发代码质量的参考;

2 因观察未通过导致jira任务的失败,可作为测试质量的参考;

3 回滚率反应团队整体工作能力的参考;

4 单位时间内完成应用升级的个数可作为工作量饱和度的参考;

5 各环节中间时长可作为工作效率的参考。

第二步:发布流程如何实现

这一部分将放在下一篇博文中,重点介绍如何实现第一阶段的设计,其中重要涉及到:Jira新项目的创建、workflow的绘制、页面排版、插件安装、自定义字段、自定义问题类型、权限控制、环节提交校验等。

第三步:如何实现自动化

为了提升生产力,利用Jira的RestfulAPI我们进一步将工具与Jira打通,这样就可以实现软件发布全生命周期的自动化运转。例如研发提交Git后会自动创建Jira任务,Jenkins构建完成后会自动提交到下一阶段,集成测试完成后自动提交到灰度阶段,甚至是上线成功后告警系统自动发现故障后会将Jira任务转移到故障阶段等等,总之就是将人工干预的比例降到最低。

以我们公司的自动化程度,预计可以做到80%-90%,如图

蓝色的环节是可以自动化实现的环节,紫色的部分代表自动化工具和对应的生命周期。

自动化如何设计?如何开发Jira的客户端代码? 我也将会在后续的博文中与大家一起分享。

作为软件行业的从业者对Jira的概念都不会太陌生,大家都应该在Jira上创建和操作过自己的任务。做为一个任务跟踪工具,Jira内置的workflow和管理员工具基本可以满足我们日常的工作。但是如何才能发挥出Jira的最大价值,结合企业自己的需求去挖掘Jira更高级的应用呢?我打算以一个案例,分为3期来深挖下Jira的高级应用方式。Jira高级应用—设计篇如何利用Jira来优化工作流程,提高...
适用于Laravel 5.5的 Jira API客户端 使用Laravel 5.5+执行各种操作 该软件包的目的是使与API的通信变得更加容易。 默认情况下,来自请求的响应不会以任何方式更改。 通过创建您自己的实现或该软件包随附的简单帮助程序,您可以按自己的方式集成 Jira 。 要获取最新版本的 jira -rest-client ,请运行以下命令 composer require kenuo/ jira -rest-client 请注意,并非所有方法都已实现。 Laravel 5.5使用包自动发现,因此不需要您手动添加ServiceProvider。 Laravel 5.5: 如果您不使用自动发现,请将ServiceProvider添加到config/app.php的providers数组中 'providers' => [ // ... Atlassian \ Jir
心比天高,仗剑走天涯,保持热爱,奔赴向梦想!低调,谦虚,自律,反思,成长,还算是比较正能量的博主,公益免费传播……内心特别想在AI界做出一些可以推进历史进程影响力的东西(兴趣使然,有点小情怀,也有点使命感呀)…… 09-22
Jira 使用手册 1    概述 跟踪并管理在项目开发和维护过程中出现的问题(如:缺陷、新特性、任务、改进等)是项目管理很重要的任务,但是很少有团队能做的很好。 JIRA 作为一个专业的问题跟踪系统可以帮助您把缺陷管理起来,让跟踪和管理在项目中发现的问题变得简单,而且充分利用 JIRA 的灵活配置和扩展特性,可以将 JIRA 作为一个项目管理系统或者IT支持系统。 2 JIRA 特性 看到网上有的文章说 JIRA 是使用Textile这门标记语言,有些语法和Wikitext和Markdown相像。 JIRA 在2017年进行了一次大更新,某些语法可能和以前不大一样,这里纪录一下常用的一些语法。 h1.一级标题 h2.二级标题 h3.三级标题 h4.四级标题 h5.五级标题 用法示例: h1.ddd 一共有h1到h5这五种大小的标题,但是h6也是有效果的,不过h6起到的作用...
1 什么是 JIRA JIRA 是目前比较流行的基于Java架构的管理系统,由于Atlassian公司对很多开源项目实行免费提供缺陷跟踪服务,因此在开源领域,其认知度比其他的产品要高得多,而且易用性也好一些。同时,开源则是其另一特色,在用户购买其软件的同时,也就将源代码也购置进来,方便做二次开发。 JIRA 功能全面,界面友好,安装简单,配置灵活,权限管理以及可扩展性方面都十分出色。 2 主要功能 问题追踪和管理:用它管理项目,跟踪服务、bug、需求、通过 jira 的邮件通知功能进行协作通知,在实际工作中使工作效率
随着互联网行业的快速发展,互联网公司也面临着越来越激烈的竞争。互联网公司每生产一个产品,都要涉及很多部门角色协作,来共同完成,譬如产品、交互、视觉 、前端开发 、后端开发、测试、 运维 、PMO(项目管理部)等多个部门的共同协作。如何提升组织内部各部门管理的效率和效果?这对于处于不同发展阶段的企业来说都是很重要的研究课题。 工具是项目运作的承载 项目管理的四个核心要素可以总结为SPPT
Jira 和 Confluence 是 Atlassian 公司推出的企业级项目管理和团队协作产品,这两款明星产品的关系就像咖啡和甜甜圈,单独品尝很棒,结合在一起使用效果绝佳。很多创业公司和大型企业在管理工具的演进过程中都或多或少使用过它们。 但是由于缺乏专业顾问的指导和最佳实践的指引,很多公司在导入 Jira 过程走得并不顺利,过多的“反对声音”导致最终的“夭折”。在笔者看来,行业上的项目管理工...
我理解您的问题了,its- jira 是一个 JIRA 插件,它可以将Gerrit代码审查工具与 JIRA 集成在一起,提供更好的协作和问题追踪功能。下面是将its- jira 连接到Gerrit的步骤: 1. 安装并启用its- jira 插件。 2. 在Gerrit中创建一个OAuth客户端。 3. 在 JIRA 中配置Gerrit OAuth客户端信息。 4. 在 JIRA 中配置its- jira 集成信息,包括Gerrit服务器URL和OAuth客户端信息。 5. 在Gerrit中配置webhook,使其能够向 JIRA 发送事件。 完成这些步骤后,您就可以在 JIRA 中跟踪Gerrit代码审查请求的状态,以及将 JIRA 问题与Gerrit合并请求关联起来。希望以上信息能够对您有所帮助。