以下的22个问题基本上涵盖了Scrum所涉及的内容,如果你能够正确回答出所有问题,那么你已经具备了作为一名Scrum Master的基本素质;当然,作为一名合格的Scrum Master,更重要的是你的经验,因为Scrum Master更多的需要和人打交道,很多实际问题的处理方式是必须在实践中才能体会的,有些还很微妙。

也许你对这些问题的答案不尽相同,这没有关系;这些答案是我根据自己的经验给出的,你所使用的方法和理解不一定一样,这也正是Scrum的特色之一,它帮助你找到最适合你的方式,它并不是你需要严格执行的流程,而是帮助你找到适合自己的流程的框架。

1. 实施Scrum模式的好处有哪些?

– 降低变更对系统造成的风险
– 提高ROI(投入产出比)
– 帮助我们持续改进
– 持续快速的发布可用的软件产品
– 所有人对真实可用的软件产品都有明确的认识,并在迭代过程中不停的改进

2. Scrum包含怎样的组织结构?

Scrum的组织结构根据不同的项目不同而不同,一般来说,它采用2-4周的迭代周期,并包含以下角色
– Scrum Master
– Product Owner
– 团队

3. 请解释Scrum中的用户情景是什么?

在Scrum中,用户情景是一个短小的,一般用一句话可以说明的特性或者功能的描述。

4. Scrum过程中都使用哪些工件/工具?

Scrum所使用的工具很简单,主要包括
– 冲刺积压工作列表 Sprint Backlog
– 产品积压工作列表 Product Backlog
– 团队速率图 Velocity Chart
– 燃尽图 Burn-down Chart

5. 请解释Scrum的冲刺

Scrum项目采用一个接一个的“冲刺”完成开发工作。冲刺是一个可重复的,标准化的工作循环单元,在这个单元中采用了Scrum的各种方法,并随时准备进行评审和改进。

6. 最佳的冲刺周期是多长,这个周期对工作方式有怎样的影响?

Scrum采用2-4周的冲刺周期。一般来说,大多数团队采用2周的周期,这主要是因为2周的冲刺让团队更加容易和接近现实的进行规划并完成手头的工作。同时,2周的长度也给予Product Owner足够的时间来调整优先级,并给团队和业务需求之间提供足够的缓冲,让他们可以专注于现有需求的开发。

7. 什么是产品积压工作列表Product Backlog?

在团队获取可用的冲刺积压工作列表sprint backlog之前,PO需要使用另外一个列表来管理新特性,变更请求,功能改进和缺陷等内容,并对他们进行优先级排序,这就是产品积压工作列表product backlog。这些内容在得到了PO和团队的认可后会交付给团队进行开发,就变成了sprint backlog,这个过程可能很复杂(比如包含多层分解,涉及多个子产品/组件,多个团队协作),也可能很简单;转换成sprint backlog的过程一般还包括了任务分解和工期估算的工作内容。

8. Scrum计划会议上一般需要做哪些工作?

在Scrum计划会议上,一般需要完成以下工作
– 团队针对当前冲刺需要完成的积压工作项进行分析,并给出工期估算
– 将产品挤压工作分解为任务
– 如果经过估算,冲刺中仍然有剩余工作量可用,则按照优先级从产品积压工作中继续拿取需求放入冲刺
– 对于需求描述中的不清晰内容与PO进行沟通,澄清

9. Scrum Master的主要职责有哪些?

– 帮助团队铲除一切阻碍,让团队可以顺利完成冲刺目标
– 帮助团队最大化生产力
– 使用技术手段帮助团队变得更加高效,比如:引入自动化脚本,单元测试,持续集成等敏捷实践
– 协助团队和PO更好的进行协作
– 保证Scrum实践的正确推行

10. 燃尽图应该包含哪些元素?

燃尽图应该包括工作日作为横轴,工作量作为纵轴,最佳曲线,真实工作进度曲线。

11. 列出Scrum的不足

– 对于目标不够清晰的项目,Scrum Master比较难以把控
– Daily scrum在开始阶段会让团队感受比较大的压力,并占用一定的工作时间
– 对于团队成员的技术水平,协作水平有较高要求
– Scrum中对于变更的容忍度非常高,但这也会让项目干系人感受比较大的不安
– 会暴露非常多的问题,如果组织对于变化的接受度不高,会有很大的组织性冲击
– 对引发很多变革的发生,一定程度造成混乱的局面

12. 什么是Scrum of Scrum?

一般在大型团队中很常见,就是每天的Daily Scrum后,团队负责人还会参加更多的会议进行团队间的沟通和进一步的规划。

13. 什么是“增量(Increment)”?

增量指在一个冲刺内完成的产品积压工作项的数量,在每一个冲刺结束时,所有的增量必须处于完成状态。这里的完成必须是可以用的,可部署的,无论PO是否决定进行新的生产部署。

14. 团队速率 Velocity

速率是一个团队在一个冲刺内能够完成的需求量,需求量的单位一般使用工作量或者商业价值衡量。工作量使用“故事点”来代表,商业价值一般也作为产品积压工作的评估指标之一。速率标识一个团队完成工作的速度,是评估团队效率的重要指标。

15. 什么是Sashimi和Impediments?

Sashimi的原意是“生鱼片”,在Scrum中是团队用来表达“完成”的一种说法;不同团队对于“完成”的定义可以是不一样的,但在一个团队内必须统一,在Scrum中一个团队需要定义不同级别的“完成规范”来统一这个概念,“完成规范”可是是任务级别的,团队级别的或者产品特定级别的。
Impediments的意思是“障碍”,是团队在向着“完成规范”所定义的状态努力过程中遇到的阻碍,一般来说,Scrum Master需要作为消除障碍的主要负责人!

16. 什么是Scrum 扑克或者计划扑克?

Scrum 扑克(计划扑克)是一种进行量化估算的方法和工具,在团队进行规划的过程中需要对工作量(故事点),商业价值等进行量化评估,为了达到评估结果可以是团队的集体决策结果的目的,Scrum中发明了这种方法和附带的工具(一种扑克),在扑克上使用斐波纳奇数列标识每张扑克,在进行规划的时候每个成员按照自己理解出牌,并由数值最大和最小的两名成员进行解释,大家进行讨论后得出最终的数值估计。

斐波纳奇数列 的特性决定了每个数字之间的差异会越来越大,这对于我们进行相对值评估非常有效。

17. 燃尽图可以说明什么问题?

燃尽图一般用来跟踪一个冲刺的进度状态,团队把燃尽图作为预测指标来使用,可以直观得看到当前进度是快还是慢。一般团队需要在Daily Scrum的最后查看燃尽图的最新状态,并根据情况采取措施。

18. 冲刺回顾会议(Sprint Retrospective)的作用是什么?

冲刺回顾会议为团队提供了总结和改进的方式,在每个冲刺结束后大家一起总结在这个冲刺中的改进和不足,并一同商讨应对措施,进行持续改进。

19. Scrum中的冲刺(Sprint)和迭代(Iteration)有什么区别?

迭代是一个通用词汇,表达的是开发过程中的某个循环过程的单元,这个单元可以是开发人员编写代码时的编写,编译,调试,重构;也可以是一个开发周期的规划,开发,测试,回归,发布;也就是说,这个单元可大可小,都可以使用迭代来进行描述。

冲刺特指在Scrum中的某个产品开发周期,是一个2-4周的规划,开发,测试,回归和发布过程。

20. Scrum中的故事点是什么意思?

在Scrum中使用用户故事(情景)作为描述一个产品特性的方式,同时使用“故事点”作为这个产品特性大小的定量估算单位,故事点的大小标识了一个产品特性的开发难度和所需要的投入(小时/人天等)。但我们一般不使用直接的小时或人天等时间单位来表示这个值,使用斐波纳奇数列中的数值来标识不同特性的相对大小,这样做的好处时我们可以屏蔽直接使用时间单位所造成的主观差异,更快更准确的进行评估(因为在没有进行实际开发之前是很难直接估算时间,但是不同特性的相对大小是比较容易评估的)。最终,我们可以使用数据分析手段在故事点单位和时间单位之间建立换算关系,帮助我们掌控项目进度。

21. 在什么情况下Scrum并不适用?

Scrum模式并不适用于所有的团队,特别当团队规模很大(几十上百上千)的时候,我们无法在整个团队范围内实施Scrum而必须将团队分割成5-10人的小团队,并在团队间进行Scrum of Scrum 的实施。
Scrum也不适合跨部门,跨职能的协作,如果团队成员分散于不同的地理位置或者不同的部门,我们需要首先在组织结构上进行调整,至少需要合并开发和测试部门,组成按照特性或产品领导的团队,同时从其他不同部门抽调人员组成团队。

22. 什么是 Daily Scrum

Daily Scrum 是一个简短的团队会议,由团队的所有成员在每天固定的时间和地点进行,会议上每个成员需要回答3个问题:1) 你昨天做了什么?2)今天计划做什么? 3)是否遇到了障碍,需要其他人的帮助?

Daily Scrum 不是一个汇报会议,因为在所有的参与者都必须抱着平等的心态参加,你所回答的3个问题是说给所有人听的,所有人的3个问题也都是说给你听的。Daily Scrum 一般由Scrum Master进行协调和组织,但Scrum Master并不对成员所描述的业务特性/任务内容进行评价,而只关注会议本身是否高效。

Daily Scrum 必须站立进行,所有有很多人称之为Daliy stand-up,站立的目的是为了让会议高效并让每个人都集中精力,放下手头的工作。


请关注微信公众号 devopshub,获取更多关于DevOps研发运维一体化的信息

原文地址 http://devopshub.cn 
 

Scrum Master 面试题 – 你必须知道的22个Scrum基础知识的更多相关文章

  1. 必须知道的ADO.NET 数据库连接池

    http://www.cnblogs.com/liuhaorain/archive/2012/02/19/2353110.html 题外话 通过前几章的学习,不知道大家对ADO.NET有一定的了解了没 ...

  2. C#刨根究底:《你必须知道的.NET》读书笔记系列

    一.此书到底何方神圣? <你必须知道的.NET>来自于微软MVP—王涛(网名:AnyTao,博客园大牛之一,其博客地址为:http://anytao.cnblogs.com/)的最新技术心 ...

  3. (转)【推荐】初级.NET程序员,你必须知道的EF知识和经验

    转自:http://www.cnblogs.com/zhaopei/p/5721789.html [推荐]初级.NET程序员,你必须知道的EF知识和经验   阅读目录   [本文已下咒.先顶后看,会涨 ...

  4. 《你必须知道的.NET》读书笔记一:小OO有大智慧

    此篇已收录至<你必须知道的.Net>读书笔记目录贴,点击访问该目录可以获取更多内容. 一.对象  (1)出生:系统首先会在内存中分配一定的存储空间,然后初始化其附加成员,调用构造函数执行初 ...

  5. 《你必须知道的.NET》读书笔记二:小OO有大原则

    此篇已收录至<你必须知道的.Net>读书笔记目录贴,点击访问该目录可以获取更多内容. 一.单一职责原则 (1)核心思想:一个类最好只做一件事,只有一个引起它变化的原因 (2)常用模式:Fa ...

  6. 《你必须知道的.NET》读书笔记三:体验OO之美

    此篇已收录至<你必须知道的.Net>读书笔记目录贴,点击访问该目录可以获取更多内容. 一.依赖也是哲学 (1)本质诠释:“不要调用我们,我们会调用你” (2)依赖和耦合: ①无依赖,无耦合 ...

  7. 《你必须知道的.NET》读书笔记:从Hello World认识IL

    通用的语言基础是.NET运行的基础,当我们对程序运行的结果有异议的时候,如何透过本质看表面,需要我们从底层来入手探索,这时候,IL便是我们必须知道的基础. 一.IL基础概念 1.1 什么是IL? IL ...

  8. MVC中你必须知道的13个扩展点

    MVC中你必须知道的13个扩展点 pasting 转:http://www.cnblogs.com/kirinboy/archive/2009/06/01/13-asp-net-mvc-extensi ...

  9. 前端开发必须知道的JS(二) 闭包及应用

    http://www.cnblogs.com/ljchow/archive/2010/07/06/1768749.html 在前端开发必须知道的JS(一) 原型和继承一文中说过下面写篇闭包,加之最近越 ...

随机推荐

  1. javascript小数点后4舍5进

    toFixed();获得小数点后面多少为数字.四舍五入的方法. 例如: var floatNum = 5.234 var temp = floatNum.toFixed(1); -- temp = 5 ...

  2. exception throw in progress runner thread_VS2015中SVN源代码无说明提交异常

    1-问题描述:通过SVN将代码变更提交服务器时,你可能会遇到以下异常:  exception throw in progress runner thread 2-解决办法: SVN代码源代码管理和TF ...

  3. for循环的执行顺序

    一边回顾基础一边记录记录做个整理,这篇关于for循环的执行顺序: for(表达式1;表达式2;表达式3) {循环体} 第一步,先对表达式1赋初值; 第二步,判别表达式2是否满足给定条件,若其值为真,满 ...

  4. Android的px、dp和sp

    Android的px.dp和sppx: 即像素,1px代表屏幕上一个物理的像素点:偶尔用到px的情况,是需要画1像素表格线或阴影线的时候. dp: 这个是最常用但也最难理解的尺寸单位.它与“像素密度” ...

  5. csharp: Export DataTable to Excel using OpenXml 2.5 in asp.net

    //https://www.microsoft.com/en-us/download/details.aspx?id=5124 Open XML SDK 2.0 for Microsoft Offic ...

  6. border-style 属性

    border-style 属性用于设置元素所有边框的样式,或者单独地为各边设置边框样式. 只有当这个值不是 none 时边框才可能出现. 例子 1 border-style:dotted solid ...

  7. structs常见错误

    原因:打开struts-default.xml文件 解决办法: 重启Myeclipse

  8. 【FOL】第三周

    这周还是在改自己的这个框架,被多线程折腾了两天,最终无奈放弃在游戏启动时调用引擎进行图片相关资源的初始化,当然进展还是不错的. 嗯,下面还是以流水的方式继续记录一下本周完成的工作: 1.调通了客户端与 ...

  9. springmvc 多数据源 SSM java redis

      A集成代码生成器 [正反双向(单表.主表.明细表.树形表,开发利器)+快速构建表单; freemaker模版技术 ,0个代码不用写,生成完整的一个模块,带页面.建表sql脚本,处理类,servic ...

  10. zDialog 可拖拽弹出层

    zDialog弹出框: 代替window.open.window.alert.window.confirm:提供良好的用户体验: 水晶质感,设计细腻,外观漂亮: 兼容ie6/7/8.firefox2/ ...