SpecDD系列:敏捷应用生命周期管理(ALM)

简介:

 由于敏捷开发正成为越来越多开发团队的标准,敏捷应用生命周期管理持续呈现增长势头。一个已经被证明了的事实,那就是很多工具供应商发现把自己的产品标识成敏捷工具甚至是敏捷ALM工具,是很管用的。
  然而,何谓敏捷应用生命周期管理?应用生命周期管理结合了技术因素和功能因素,为常见的项目活动(如开发,配置,部署,发布,测试,质量,集成,和需求管理)提供一个综合方案。
  敏捷ALM用敏捷的价值观和策略,丰富了应用生命周期管理。敏捷方法下的ALM可以提高产品质量,缩短产品上市时间,并让开发者感到快乐。传统的ALM有助于为敏捷ALM提供一个架构,同时保证过程和工具链是灵活的,可更改的和高品质的。
  个体和交互胜过过程和工具
  首先,敏捷ALM是一个准则,是一种思想。从事敏捷应用生命周期管理应该从价值观和人,以及人们背后的观念开始。敏捷ALM工具是一个能够促进敏捷过程的ALM工具。
  敏捷ALM工具必须能够为项目增加价值并改善利益相关者之间的合作。这些是通过构建敏捷ALM的基石:协作和基于任务的开发,功能/技术发布,利益相关者关注点和质量保证来实现的。
  很多团队都很乐于把几个单独的好用的工具拼凑起来用。把许多轻量级的,可配置的工具整合为一个工具链。这种混搭的工具集合通常能够提供完成一个任务所需的大部分功能。很多时候,虽然工具之间存在隔阂,但这些隔阂可能不会存在于完全整合的解决方案中。
  理想的情况下,敏捷ALM工具应该有一个整合的,灵活的架构,可以让你扩展过程和功能。依托一个完全整合的工具,可以显著提高产品安全性和沟通效率,因为你可以很容易地维护各个交付件之间的关系,并且不用担心工具间传输时会遗漏细节。现在,我们来讨论一下构建敏捷ALM基石的其他重要部分。
  基于任务的开发
  基于任务的开发方法中,任务是团队工作和交互的基本单元。基于任务的开发需要能够跟踪具体变更的关联工作项,通过追溯性定位并完成这些工作。例如,你正在处理事件系统上的一个任务。你的SCM(比如SVN)与事件系统(比如DevTrack)是相集成的,从而透明化任务的工作进度和相互依赖关系。在DevTrack中,你可以看到Sprint中每个任务的计划,它们的状态,以及已完成的代码更改。此外,DevTrack作为完整DevSuite中的一个组件,你可以为DevTrack中的任务链接原始的用户需求及可用的测试用例。
  功能性和技术性发布管理
  发布管理包括产生软件交付件,并按照既定流程发布这些交付件。发布管理可以区分为功能性的和技术性的。要想成功交付软件,这两部分都是非常重要的,并且应该相互融合。
  功能发布管理涉及到客户的需求,将这些需求分配到各个版本中,然后把功能提供给客户。经常使用敏捷实践来支撑这一过程,许多项目通过使用Scrum管理模板取得了良好的效果。通过定义一个简洁的框架,Scrum促进了规范化,并且让缺陷(软件中的以及过程中)可视化。但是,Scrum太抽象化了,有些“纸上谈兵”。你必须实施Scrum,并且使之适应软件工程。例如,实施实践可能在不同的开发阶段会存在差别,微观层面上,在一个Scrum发布内部:发布过程中,你可能会为了关闭开发阶段而考虑冻结某些新功能的开发实现,而允许开发人员只处理缺陷的修复工作。另一个有效的选择是使用一定时间间隔的代码冻结,来完成和交付最终版本。
  技术发布包括构建软件和提供最终产品给用户。构建管理(包括编译脚本,打包和分发组件)对于敏捷ALM来说是必不可少的。技术发布管理描述了以下活动:识别配置项,跟踪和审核基于需求和配置项的变更,集成和交付实施。在软件工程中,变更更像是规则,而不是例外。因为需求总是在变化的,保证需求和实施的同步是非常重要的。功能发布管理和技术发布管理之间可能存在的隔阂应该被桥接。一个完全整合的敏捷ALM工具可以通过自动创建相应的关系和链接来避免这些隔阂。
  总结
  敏捷应用生命周期管理涵盖软件工程中的许多学科。敏捷ALM关乎人和策略,以及用一个完全整合的工具套件来实施这些策略。敏捷ALM有助于为敏捷提供架构,并且通过一种果断,务实的方式来实现应用生命周期管理。使用敏捷方法来进行应用生命周期管理,你将收益更好的结果并更快的获得成功。

最新内容请见作者的GitHub页:http://qaseven.github.io/

相关文章
|
2月前
|
Android开发 开发者 UED
深入理解安卓应用开发中的生命周期管理
本文旨在探讨安卓应用开发中生命周期管理的重要性,以及如何有效利用生命周期解决常见问题。通过分析安卓应用生命周期的不同阶段及其特点,提供实用的代码示例和调试技巧,帮助开发者优化应用性能,提升用户体验。
47 8
|
2月前
|
监控 供应链 数据可视化
团队高效流程管理必备:方法与实用软件推荐
在当前激烈的商业竞争环境中,高效的业务流程管理对企业成功至关重要。本文介绍了业务流程管理的方法,包括流程梳理、优化、监控与评估及员工培训与参与,并推荐了几款实用的业务流程管理系统(BPMS)。BPMS能自动化、可视化业务流程,提升效率。具体推荐包括板栗看板、Trello和Wrike,它们分别在任务管理、团队协作及项目管理方面有各自的优势。选择合适的BPMS有助于提高工作效率、增强流程透明度、提升团队协作能力,规范管理并降低风险,从而增强企业竞争力。
78 0
|
JSON 运维 Prometheus
让应用交付和管理统一:KubeVela 亮点功能及核心技术回顾
让应用交付和管理统一:KubeVela 亮点功能及核心技术回顾
11787 0
让应用交付和管理统一:KubeVela 亮点功能及核心技术回顾
|
存储 监控 安全
「技术管理」有效技术生命周期管理的6个步骤
「技术管理」有效技术生命周期管理的6个步骤
|
敏捷开发
《规范敏捷交付:企业级敏捷软件交付的方法与实践》——1.8 目标驱动的交付生命周期
本节书摘来自华章计算机《规范敏捷交付:企业级敏捷软件交付的方法与实践》一书中的第1章,第1.8节,作者:(加)安布勒(Ambler, S. W.),(加)莱恩斯(Lines, M.)著, 更多章节内容可以访问云栖社区“华章计算机”公众号查看。
1711 0
|
测试技术
《规范敏捷交付:企业级敏捷软件交付的方法与实践》——1.3 以人为核心
本节书摘来自华章计算机《规范敏捷交付:企业级敏捷软件交付的方法与实践》一书中的第1章,第1.3节,作者:(加)安布勒(Ambler, S. W.),(加)莱恩斯(Lines, M.)著, 更多章节内容可以访问云栖社区“华章计算机”公众号查看。
1372 0
|
测试技术
《规范敏捷交付:企业级敏捷软件交付的方法与实践》——3.4 敏捷建模
本节书摘来自华章计算机《规范敏捷交付:企业级敏捷软件交付的方法与实践》一书中的第3章,第3.4节,作者:(加)安布勒(Ambler, S. W.),(加)莱恩斯(Lines, M.)著, 更多章节内容可以访问云栖社区“华章计算机”公众号查看。
1443 0
|
测试技术 数据库
《规范敏捷交付:企业级敏捷软件交付的方法与实践》——1.6 混合型过程框架
本节书摘来自华章计算机《规范敏捷交付:企业级敏捷软件交付的方法与实践》一书中的第1章,第1.6节,作者:(加)安布勒(Ambler, S. W.),(加)莱恩斯(Lines, M.)著, 更多章节内容可以访问云栖社区“华章计算机”公众号查看。
1370 0
|
敏捷开发
《规范敏捷交付:企业级敏捷软件交付的方法与实践》——2.4 精益开发原则
本节书摘来自华章计算机《规范敏捷交付:企业级敏捷软件交付的方法与实践》一书中的第2章,第2.4节,作者:(加)安布勒(Ambler, S. W.),(加)莱恩斯(Lines, M.)著, 更多章节内容可以访问云栖社区“华章计算机”公众号查看。
1615 0
|
敏捷开发
《规范敏捷交付:企业级敏捷软件交付的方法与实践》——1.1 背景——敏捷伸缩模型
本节书摘来自华章计算机《规范敏捷交付:企业级敏捷软件交付的方法与实践》一书中的第1章,第1.1节,作者:(加)安布勒(Ambler, S. W.),(加)莱恩斯(Lines, M.)著, 更多章节内容可以访问云栖社区“华章计算机”公众号查看。
1641 0
下一篇
DataWorks