从瀑布型开发到迭代型开发的转变_第1页
从瀑布型开发到迭代型开发的转变_第2页
从瀑布型开发到迭代型开发的转变_第3页
从瀑布型开发到迭代型开发的转变_第4页
从瀑布型开发到迭代型开发的转变_第5页
已阅读5页,还剩5页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

从瀑布型开发到迭代型开发的转变作者:日期:从瀑布型开发到迭代型开发的转变developerWorks.文档选项级别:初级文档选项PerKroll(pkroll@),Director,RationalUnifiedProcess,IBM2004年4月01日本文来自RationalEdge:一个理想的迭代开发方法模型在很多方面与理想的瀑布开发模型有着根本上的不同。但是,从实际来说,没有一个团队严格的应用了每一种开发方法模型。本文解释了为什么开发团队决定逐步的从类似瀑布型的开发方法转变成更加类似迭代开发的方法,同时也概述了能够帮助这种转变的步骤。多数的软件开发团队仍然在开发项目中使瀑布型的开发过程。采用极端的瀑布型开发方法意味着你要以严格的顺序来完成一系列的项目阶段:需求分析、设计、实现集成然后是测试。当项目中出现的问题解是困难的并且解决问题是昂贵时,你可能会推迟测试直到项目周期的末端;这些问题也能够严重的威胁软件发布的期限并且使主要的团队成员在某些开发环节上是空闲的。实际上,多数的开发团队使用戟进了的瀑布型开发方法,他们将项目分解成为两个或者更多的部分,有时这些部分被称为阶段或者是时期。这种改良可以帮助简化集成、使测试人员更早的进行测试工作和提供更早的项目状态的观测。这种方法也将代码分解成了易于管理的片断并最小化了以存根和驱动程序形式的、被测试需要的代码集成。此外这种方法允许你原型化你认为有风险的或者有难度的部分,并且使用来自每一个阶段的反馈修改你的设计。然而,使用瀑布型开发方法的执行与想象是相反的很多设计团队把在阶段7之后的修改设计视为他们的最初设计或者需求过程的失败。虽然一个改进了的瀑布型开发方法并不排除反馈的使用,但是它并没有促进、支持和鼓励反馈的使用。最后,想要最小化风险就不要典型的驱动一个瀑布型的开发项目。对于软件开发过程来说,本文探索了迭代开发方法超越传统的瀑布型开发方法的进步。迭代开发的好处相比较而言,迭代开发方法一以IBM的Rational统一过程®,或者RUP®为例一包括了一系列的增量的步骤或者迭代。每一个迭代都包括一些或者很多的开发活动(需求、分析、设计、实现等等),就像你在图1中看到的那样。每一个迭代也有一系列良好定义的目标并生成最终系统的部分工作实现。每个后续的迭代都建立在前一个迭代的基础上以使系统得到发展和细化,直到最终产品被完成。早期的迭代着重于需求、分析和设计;后期的迭代着重于实现和测试。

RequirementsBusinessRequirementsModelingPlanningInitialPlannrng图1:RUP的迭代开发。每一个迭代都包括需求、分析、设计、实现和测试活动。同时,每个迭代都建立在前一个迭代工作的基础上,每一次迭代都会生成更加接近最终产品的可执行版本。迭代开发方法已经证明了自己优于瀑布型的开发方法,理由如下:•它允许需求的变化。需求的变化和“进一步的蔓延”一技术和客户驱动的特性的累加一一直是项目中导致麻烦、延期交付、令客户不满意和使开发人员泄气的主要原因。为了解决这些问题,使用迭代开发方法的团队应该在项目开发的几周里就关注生成和演示可执行的软件,这样就强制了需求的检查并可以帮助减少需求从而反映系统的本质。•集成不是在项目的尾声进行的“大动作”。将系统的集成留到项目的结尾几乎总是会导致耗时的返工一有时这种返工会花费整个项目工作量的百分之四十的时间。为了避免这种返工,每一次迭代都以集成构建系统各部分结束;这样不断的积累将最小化日后的返工。•早期的迭代可以暴露风险。迭代的开发方法可以帮助团队在早期的迭代中减少风险,因为在这些迭代中包括了对所有过程组件的测试。当早期的迭代覆盖了项目的很多方面时一工具、购买的软件和团队成员的技能等等一团队能够很快的发现被预感的风险是否是真实的,并且能够在问题相对容易并花费很少成本解决时揭示没有被发现的新的风险。•对产品的管理能够采取战术性的变化。迭代开发能够快速的生成可执行的架构(虽然功能有限),这个架构能够为了应对竞争对手的快速版本

发布容易的调整产品使之成为”轻量级的“或者“改进的”版本。•它使重用更加容易。识别在迭代中进行的部分设计和实现的公用部分要比在计划期间找出公用部分更加容易。在早期开发中的设计评审允许架构师们发现潜在的可重用的机会,并且利用这个机会为接下来的迭代开发成熟的公用代码。•你能够在每一个迭代中发现并更正缺陷。这会生成健壮的架构和高质量的应用。你甚至能够在早期的迭代中而不是在项目末期的大规模测试阶段发现缺陷。你能够在性能瓶颈没有破坏你的计划之前发现它。•它能够更好的利用项目的人员资源。很多开发组织使用一种管道式的组织方式来匹配他们的瀑布型开发方法:分析人员将被完成的需求发送给设计人员,设计人员将被完成的设计发送给开发编程人员,编程人员再将他们开发的组件发送给集成人员,集成人员将组件集成起来发送给测试人员测试。这种多次的传递不仅容易产生错误而且应用造成误解;这种方式也会使人们感觉他们对最终的产品有很少的责任。迭代开发过程鼓励在项目的各个环节中团队成员参与范围更加宽广的活动,允许团队成员扮演多种角色。项目经理能够更好的利用可得到的项目人员并其可以消除有风险的传递。•团队成员能够沿着项目的道路进行学习。工作在迭代开发的项目中的开发人员在软件开发周期内有很多的机会从他们所范的错误中吸取教训,并能够从一个迭代到另一个迭代的过程中增进他们的技能。通过评估每一个迭代,项目经理能够为团队成员发现培训的机会。相反,工作在瀑布型开发方法中的开发人员典型的被限制在狭窄的技术专长上,并且仅仅有机会从事设计、编码或者测试之一方面的工作。•你能够沿着项目的道路改进开发的过程。迭代末尾的评估不仅能够从产品或者计划方面揭示项目的状态;他们也可以帮助项目经理分析在下一个迭代中如何改进项目的组织结构和过程。一些项目经理反抗采用迭代的开发方法,将迭代开发视为一种没有尽头的、不可控的形式。然而,在RUP中,这个项目是能够被很好的控制的。迭代的次数、周期和目标被仔细的计划;并且项目参与者的任务和角色被良好的定义。此外,进展的客观量度应该能够被获取。虽然团队要从一个迭代到下一个迭代中重做一些事情,但是这个工作也是可以被仔细的控制的。转化的四个步骤多数的瀑布型的项目将开发工作划分为阶段或者时期;我们也可以将这个划分视为向迭代方法转换的第一步。但是为了实现向迭代开发方法的过渡,我们要

使用下面四个步骤来应用不同的过程原则:尽早的构建功能原型。划分详细设计、实现和测试阶段到不同的迭代中。在项目早期基线化一个可执行的架构。采用迭代式的和风险驱动的管理过程。让我们来更进一步的解释每一个步骤。步骤1:尽早的构建功能原型作为向迭代开发转换的第一步,在需求和设计阶段考虑一个或者更多的功能原型。这些原型的目标是减少主要的技术风险和澄清项目涉众对系统应该做什么的理解。通过识别最重要的三个技术风险和最重要的三个有必要澄清的功能部分开始。技术风险也许与新技术、对整个方案影响很多的未决定的技术选择或者你知道的很难满足的技术需求有关。功能上的风险也许与项目涉众为关键的功能性提供了模糊的需求或者几个需求对项目系统都是核心的有关。对于每一个重要的技术风险,拟订你要原型化什么以减少风险。考虑一下下面的例子:技术风险:项目需要将一个已存在的应用移植到IBMWebSphereApplicationServer上运行。用户已经开始抱怨应用的性能,并且你所担心的是移植后也许性能会更加的慢。原型:构建一个架构的原型来找出移植你的应用的不同方法。要求一个专家级的WebSphere架构师来帮助你。评价结果并编写架构的和设计的指导方针为开发团队提供什么应该做和什么不应该做这将增加你移植的应用的性能是足够好的以避免在项目后期返工的可能性。技术风险:你正在为安排和估计软件项目构建一个新的应用。你知道对于这个应用和购买的软件的关键区分将是如何能够很好的支持迭代计划。然而,这也是在你的需求说明中最模糊的部分之一。原型:基于你关于如何支持迭代项目计划的设想构建一个功能原型。通过向不同的项目涉中演示原型,你将可以鼓励他们更加注意项目的计划,并且他们能够告诉你他们对你的哪些设想是赞同的、哪些是不赞同的。原型将帮助你澄清计划的需求,也能够为你提供关于用户体验和对于你的应用的外表和感觉的有用的信息。这个原型甚至能够产生一些可重用的代码。步骤2:划分详细设计、实现和测试阶段到不同的迭代中。很多项目团队发现在他们知道项目是真正关于什么的之前划分一个项目成为有意义的迭代是困难的。但是,当你已经进入了详细设计阶段时,你通常对需求是什么和系统的架构看起来象什么样子有了很好的理解。这是我们试验迭代开发的时候了!你能够使用两个主要的方法来确定你应该在什么样的迭代中作些什么事情。让我们从正反两方面讨论一下每一个方法。方法1:同时开发一个或者多个子系统。让我们假设你有九个子系统,每一个

都有数量日益增加的组件。你可以划分详细设计、实现和测试阶段到三个迭代中,每个迭代瞄准实现九个子系统中的三个。如果在不同的子系统之间存在有限的依赖这将工作的相当的好。例如,如果你的九个子系统的每一个都为用户提供良好定义的一系列能力,你可以在第一个迭代中开发优先级最高的子系统,其次重要的子系统在第二个迭代中实现,以此类推。这种方法有很大的优点:如果你的进度落后了时间计划,你仍然可以交付可运行的具有最重要能力的部分系统。然而,如果你有一个分层的体系架构,在上层的子系统依赖于底层子系统的能力,这种方法将不能够很好的工作。如果你必须要在一个时间内构建一个子系统,这样的体系架构将迫使你首先构建底层的子系统,然后构建越来越上层的子系统。但是为了构建在底层子系统的正确的能力,你通常需要在上层的子系统上进行大量的详细设计和实现的工作,因为他们决定了什么是你在底层子系统中需要的。这产生了“catch-22”的现象;第二个方法解释了如何解决这个问题。方法2:首先开发最重要的场景。如果你使用方法1,你一次只能开发一个子系统。使用方法2,你将重点放在了重要的场景上,或者使用系统的关键方法上,然后再添加更多的不是那么重要的场景。这与方法1有什么不同呢?让我们来看一个例子。假设你正在构建一个新的应用,这个应用将为用户提供管理缺陷的能力。这是一个分层的应用,被构建在WebSphereApplicationServer上,使用DB2作为底层的数据库。在首先的迭代中,你开发了一系列重要的场景,比如输入一个简单的缺陷。在第二次迭代中,你为这些场景添加了复杂性一例如,你也许使缺陷能够被一个工作流来处理。在第三次迭代中,你通过为非典型的用户提供完整的支持,比如保存部分的缺陷条目然后返回到这个条目中的能力等等。使用这种方法,你在所有的迭代中完成所有的子系统的工作,但是在第一个迭代中你仍然关注最重要的场景,而将不是非常重要的或者最小难度的场景留到最后的迭代中实现。如果你正工作在一个良好定义的体系架构的系统中时,方法1是更加适合的—比如,一个已存在系统的增进或者开发使用简单体系架构的新应用。多数构建复杂应用的项目应该使用方法2,但是他们应该以这样的方式来计划迭代,这种方法能够削减后来迭代的范围以弥补可能的时间推延。步骤3:在项目的早期基线化一个可执行的架构。你可以将这个步骤看作是更加正式和有组织的完成步骤1 (尽早的构建功能原型)的方法。但是什么是“可执行的架构”呢?可执行的架构是系统的部分的实现,它被构建以演示架构的设计所支持的关键的功能。更重要的是,它能够证明设计能够满足对于性能、生产能力、容量可靠性、可测量性和其他方面的需求。构建一个可执行的架构允许你在稍后的阶段中在一个坚实的基础上构建所有的系统功能性的能力。这个可执行的架构是一个进化的原型它的目的是当系统的架构成熟时,保持已经被证明的特性并保证他们最大可能的满足系统的需求。换句话说,这些特性将是交付系统的一部分。与你在步骤1中构建的功能原型相比,这个进化的原型覆盖了架构问题的所有方面。生成一个进化的原型意味着你要设计、实现和测试一系统的个框架结构或者架

构。在应用的角度上,系统的功能还没有被完成,但是大多数的构建模块之间的接口已经被实现了,你能够(并应该)在某种程度上编译并测试架构。指导初始的负载和性能测试。这个原型也会反映你的关键设计的决定,包括技术、主要组件和他们之间接口的选择。但是你将如何为这个进化的原型提出系统的架构呢?关键是将重点放在最重要的百分之二十到三十的用例上(系统为用户提供的完全的服务)。这里是一些决定什么用例是最重要的方法。•功能是应用的核心,或者它使用的关键的接口。系统的关键功能应该能够决定系统的体系架构。通常的情况下架构师通过分析很多因素来识别最重要的用例:冗余管理策略、资源争夺风险、性能风险和数据安全策略等等。例如,在一个POS系统中,检查(CheckOut)和支付(Pay)是关键的用例,因为它验证了信用卡确认系统的接口一并且它从性能和负载方面也是重要的。•选择描述了必须被交付功能的用例。交付不包含关键功能的应用系统是没有意义的。例如,一个订单输入系统如果不允许用户输入订单将是不可接受的。通常,领域和问题专家能够从用户的角度理解被需要的关键功能(主要的行为、峰值数据处理、关键控制事务等等),并且他们可以帮助定义关键的用例。•选择描述了系统体系架构方面的功能并且没有被其他关键用例所包含的用例。为了确保你的团队能够将注意力放在所有主要的技术风险上,他们必须理解系统的每一个区域。甚至如果一定的架构领域没有出现在高风险中,它也许是隐藏了技术上的难度,这种技术上的难度仅仅能够通过设计、实现和测试架构领域的一些功能才能够被暴露出来。上面所列出的第一个和最后一个标准是架构师最关心的;项目经理主要关注于前两个。对于每一个关键的用例,识别最重要的场景并用他们创建可执行的系统架构。换句话说就是设计、实现和测试这些场景。步骤4:采用迭代式的和风险驱动的管理过程。如果你将要遵循上面所描述的步骤2和步骤3,那么你将会非常的接近“理想”迭代开发的模型。那么,你接下来的步骤应该是融合步骤2和步骤3,并添加支持风险驱动和迭代开发的管理生命周期。这就是在RUP中被描述的迭代开式的生命周期。RUP对迭代开发提供了一个结构化的方法,它将一个项目划分成为四个阶段:初始阶段、细化阶段、构建阶段和转换阶段。每一个阶段包含了一个或者更多的迭代,每个迭代都关注于产生必要的技术上的可交付物以实现阶段的业务目标。团队经历的迭代次数与需要实现阶段的目标的数量是一样的,而不是更多。如果在团队计划的迭代次数内他们没有成功的实现这些目标,他们必须为那个阶段添加额外的迭代一并且推迟项目。为了避免这种事情发生,你一定要严格的将你的精力集中在每个阶段你需要实现的业务目标上。例如,在初始阶段将精力过于集中在需求上将会成生相反的效果。下面是典型的阶段目标的简要描述。

•初始阶段:通过获得对所有需求的高层次的理解和确立系统的范围来建立对系统将要构建什么的良好理解。减少多数的业务风险,为构建系统产生业务用例,并从所有项目决策人得到是否继续项目的确认。•细化阶段:关心多数最具技术难度的任务:设计、实现、测试和基线化一个可执行的系统架构,包括子系统、他们的接口、关键组件和架构上的机制(例如,如何处理进程间通讯或者持久性问题)。通过实现和验证实际的代码,处理主要的技术任务,比如资源争夺风险、性能风险和数据安全风险。•构建阶段:当你从一个可执行的系统架构迁移到系统的第一个可操作的版本时,需要完成大半的实现工作。部署

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论