Scrum介绍

发表于2017-09-11
评论0 2.3k浏览
       Scrum是一种迭代式增量软件开发过程,通常用于敏捷软件开发。Scrum在英语的意思是橄榄球里的争球。

  虽然Scrum是为管理软件开发项目而开发的,它同样可以用于运行软件维护团队,或者作为计划管理方法:Scrum of Scrums.

  Scrum历史

  1986年,竹内弘高和野中郁次郎阐述了一种新的整体性的方法 ,该方法能够提高商业新产品开发的速度和灵活性:他们将这种新的'整体性方法与橄榄球相比较,前者各阶段相互重叠,并且由一个跨职能团队在不同的阶段完成整个过程,而后者整个团队"tries to go to the distance as a unit, passing the ball back and forth"。他们对来自汽车,照片机器,计算机和打印机等产业的案例进行了研究。

  1991年,DeGrace和Stahl在《Wicked Problems, Righteous Solutions》一书中将这种方法称为 Scrum,在竹内弘高和 野中郁次郎的文章中提到的橄榄球术语。

  1990年代初,肯·施瓦伯在其公司使用了一种方法Advanced Development Methods(先进开发方法),这种方法后来发展为Scrum。

  同时,杰夫·萨瑟兰在Easel公司开发了一种类似的方法,并首次称之为Scrum。

  1995年,在奥斯汀举办的OOPSLA '95上,萨瑟兰和施瓦伯联合发表了论文首次提出了Scrum概念。施瓦伯和萨瑟兰在接下的几年里合作,将上述的文章,他们的经验,以及业界的最佳实践融合起来,形成我们现在所知的Scrum。

  2001年,施瓦伯与 麦克·比窦(Mike Beedle)合著了《敏捷软件开发-使用Scrum过程》一书,介绍了Scrum方法。

  Scrum特性

  Scrum是一个包括了一系列实践和预定义角色的过程骨架。Scrum中的主要角色包括同项目经理类似的Scrum主管角色负责维护过程和任务,产品负责人代表利益所有者,开发团队包括了所有开发人员。

  在每一次冲刺(一个15到30 天周期 ,长度由开发团队决定),开发团队创建可用的(可以随时推出)软件的一个增量。每一个冲刺所要实现的特性来自产品订单(product backlog), 产品订单是按照优先级排列的要完成的工作的概要的需求。那些订单项会被加入一次冲刺由冲刺计划会议决定。 在会议中,产品负责人告诉开发团队他需要完成产品订单中的哪些订单项。开发团队决定在下一次冲刺中他们能够承诺完成多少订单项。[4] 在冲刺的过程中,没有人能够变更冲刺订单(sprint backlog),这意味着在一个冲刺中需求是被冻结的。

  管理Scrum过程有很多实施方法,从白板上的即时贴到软件包。Scrum最大的好处是它非常容易学习,而且应用Scrum不需要太多的投入。

  Scrum中的角色

  Scrum定义了许多角色,根据猪和鸡的笑话分为两组,猪和鸡。

       

  一天,一头猪和一只鸡在路上散步,鸡看了一下猪说,“嗨,我们合伙开一家餐馆怎么样?”,猪回头看了一下鸡说,“好主意,那你准备给餐馆起什么名字呢?”,鸡想了想说“餐馆名字叫火腿和鸡蛋怎么样?”,“我不这么认为”,猪说,“我全身投入,而你只是参与而已”

  1."猪"角色,猪是全身投入项目和Scrum过程的人; they are the ones with "their bacon on the line."

  2.产品负责人,产品负责人代表了客户的意愿。这保证了Scrum团队在做从业务角度来说正确的事情。产品负责人编写 用户故事,排出优先级,并放入产品订单。

  3.Scrum主管(或促进者)Scrum主管促进 Scrum过程,他的主要工作是去除那些影响团队交付冲刺目标的障碍。Scrum主管并非团队的领导(由于他们是自我组织的),而是负责屏蔽外界对开发团队的干扰。Scrum主管确保Scrum过程按照初衷使用。Scrum主管是规则的执行者。

  4.开发团队,负责交付产品的团队。由5至9名具有跨职能技能的人(设计者,开发者等)组成的小团队完成实际的开发工作。。

  "鸡"角色

  1.鸡角色并不是实际Scrum过程的一部分,但是必须考虑他们。 敏捷方法的一个重要方面是使得用户和利益相关者参与到过程中的时间。参与每一个冲刺的评审和计划,并提供反馈对于这些人来说是非常重要的。

  2.用户,软件是为了某些人而创建!就像“假如森林里有一棵树倒下了,但没有人听到,那么它算發出了声音吗”,“假如软件没有被使用,那么它算是被开发出来了么?”

  3.利益所有者(客户,提供商),影响项目成功的人,但只直接参与冲刺评审过程。

  4.经理,为产品开发团体架起环境的那个人

  Scrum会议

  在冲刺中,每一天都会举行项目状况会议,被称为“scrum”或“每日站立会议”。每日站立会议有一些具体的指导原则:

  会议准时开始。对于迟到者团队常常会制定惩罚措施(例如罚款,做俯卧撑,在脖子上挂橡胶鸡玩具)

  欢迎所有人参加,但只有"猪"可以发言。

  不论团队规模大小,会议被限制在15分钟。

  所有出席者都应站立。(有助于保持会议简短)

  会议应在固定地点和每天的同一时间举行。

  在会议上,每个团队成员需要回答三个问题:

  今天你完成了那些工作?

  明天你打算做什么?

  完成你的目标是否存在什么障碍?(Scrum主管需要记下这些障碍)

  每一个冲刺完成后,都会举行一次冲刺回顾会议,在会议上所有团队成员都要反思这个冲刺。举行冲刺回顾会议是为了进行持续过程改进。会议的时间限制在4小时。

  Scrum提倡所有团队成员坐在一起工作,进行口头交流,以及强调项目有关的规范(disciplines),这些有助于创造自我组织的团队。

  Scrum的一个关键原则是承认客户可以在项目过程中改变主意,变更他们的需求,而预测式和计划式的方法并不能轻易地解决这种不可预见的需求变化。同样,Scrum采用了经验方法– 承认问题无法完全理解或定义,而是关注于如何使得开发团队快速推出和响应不断出现的需求的能力最大化。

       文档

  1.产品订单

  产品订单(product backlog)是整个项目的概要文档。产品订单包括所有所需特性的粗略的描述。产品订单是关于将要创建的什么产品。产品订单是开放的,每个人都可以编辑。产品订单包括粗略的估算,通常以天为单位。估算将帮助产品负责人衡量时间表和优先级(例如,如果"增加拼写检查"特性的估计需要花3天或3个月,将影响产品负责人对该特性的渴望).

  2.冲刺订单

  冲刺订单(sprint backlog)是大大细化了的文档,包含团队如何实现下一个冲刺的需求的信息。任务被分解为以小时为单位,没有任务可以超过16个小时。如果一个任务超过16个小时,那么它就应该被进一步分解。冲刺订单上的任务不会被分派,而是由团队成员签名认领他们喜爱的任务。

  3.燃尽图

  燃尽图(burn down chart)是一个公开展示的图表,显示当前冲刺中未完成的任务数目,或在冲刺订单上未完成的订单项的数目。不要把燃尽图与挣值图相混淆。A burn down chart could be flat for most of the period covered by a sprint and yet the project could still be on schedule.

  4.自适应的项目管理

  以下是一些Scrum的通用实践:

  客户成为开发团队中的一部分。(例如客户肯定对开发的结果真正感兴趣。)

  和所有其他形式的敏捷软件过程一样,Scrum有频繁的包含可以工作的功能的中间可交付成果。这使得客户可以更早的得到可以工作的软件,同时使得项目可以变更项目需求以适应不断变化的需求。

  频繁的风险和缓解计划是由开发团队自己制定。– 在每一个阶段根据承诺进行风险缓解,监测和管理(风险分析)。

  计划和模块开发的透明 – 让每一个人知道谁负责什么,以及什么时候完成。

  频繁的利益所有人会议,以跟踪项目进展 – 平衡的(发布,客户,员工,过程)仪表板更新 – 利益所有者更新 – 你必须拥有预警机制,例如提前了解可能的延迟或偏差。

  没有问题会被藏在地毯下。认识到或说出任何没有预见到的问题并不会受到惩罚。

  在工作场所和工作时间内必须全身心投入。– 完成更多的工作并不意味着需要工作更长时间。

   Scrum术语

  1.产品负责人

  负责维护产品订单的人,代表利益相关者的利益。

  2.Scrum主管

  为Scrum过程负责的人,确保scrum的正确使用并使得Scrum的收益最大化。

  3.开发团队

  由负责自我管理开发产品的人组成的跨职能团队。

  4.Scrum团队

  产品负责人,Scrum主管和开发团队。

  工件

  1.冲刺燃尽图

  在冲刺长度上显示每天进展的图。

  2.产品订单

  按照优先级排序的高层需求。

  3.冲刺订单

  要在冲刺中完成的任务的清单。

  其他

  1.冲刺

  一个时间周期(通常在2周到1个月之间),开发团队会在此期间内完成所承诺的一组订单项的开发。

如社区发表内容存在侵权行为,您可以点击这里查看侵权投诉指引