前段时间,我们发现开发过程有些混乱并且不容易管理。为了团队更好的协作,我们在顾问的引导下,开始尝试使用Scrum敏捷开发。(Scrum相对官方的资料,附在文章最后) 几轮Sprint下来,有点个人体会,和大家share之。立场当然是是不褒不贬,纯客观描述啦!不过,每个团队情况不一致;因此,这个"客观"针对的是我们团队。啊哈~ 首先,Scrum的官方流程如下: 我们的Scrum流程如下: 接下来会详细讲解每个步骤中应当注意的点: 开发前: 阐述&调整需求: 产品要在这之前需要考虑清楚每个需求的逻辑、页面交互展示,不然在这一步就会造成很多讨论,延长开会时长,影响效果。至于如何思考清楚内在逻辑,有多钟方法,这又是一个topic; 对于优先级的确认,一定要明确,这是后面实现的先后基础; 如果程序猿们对某个需求逻辑提出质疑的话,最好不要太任由发散讨论,能立刻调整的,那么就调整;不能立刻确认调整的,先保留,然后在真正开发前要确认; 如果产品汪在阐述需求的同时,开发人员们开始相互沟通如何实现的问题,那么建议开发们先听完所有内容,在后面的需求分解中再进行详细讨论,不然在需求源头错过就容易有需求上的认知偏差; 需求分解为任务: 小团队没有项目经理的情况下,建议项目负责人(Scrum Master)是经验比较丰富的技术人,这样对项目进度比较容易有把控,同时对需求的分解以及后期的追踪会有很大的帮助; 要强化需求追踪人(Owner)追踪需求的意识,不要流于形式:有个这么个角色,但是并没有发挥作用这种情况。owner的存在可以分担SM的责任的同时让开发人员之间关联性更强,因为一般某个需求会同时涉及到前端、后端、API、移动端,让开发去推动开发; 开发人员们要适当把需求拆的细一些,这样在拆的过程中更容易吃透需求、理清逻辑,发现逻辑上的问题。针对需求,相关的人进行技术讨论,有疑问的地方要及时和产品这边沟通,问题越早发现越好。最后,要把每个任务对应的人以及需要的完成时间都记录下来。 有关于时间预估问题,我暂时还不知道哪种方法比较好。在文末最后有个敏捷估算的方法,乃们可以参考看看。 在拆分的过程中,SM最好能够根据需求的难易程度,进行辅助沟通。这样,能够相对避免因为具体代码人员因为经验/能力不够而导致的拆分、预估问题; 产品汪要在讨论过程中,时刻穿插在其中,尽量保证需求理解的正确性; 确认该期目标: 完整过一遍每个需求的分解情况,看是否有遗漏或者误差,有疑问即刻提; 必须按照需求的优先级来确认目标; 要明确目标,确认哪些一定要做完(这里有个argue/挖坑的地方,会在下文"开发中"-"3其他"-2中进行描述); 开发中: 有关中期会议: 一定要在一期sprint的中间进行进度回顾和确认,如果进度偏差很大的话,要适当的调整目标,以免最终跟预期相差太大; 中期的时候,可以check下人力分配,如果有相对空闲,那么可以再安排一些任务。看不同情况,是安排产品线的新任务还是基础建设任务或是代码优化任务等等; 有关测试: 在开发过程中,建议开发完一个功能就跟进一个功能的测试,以免最终测试任务都堆积起来; 提测可以在项目结束的前2-3天开始,这样可以保证有足够的时间进行修正; 如果功能和业务强关联,可以让业务人员在提测阶段使用测试版本,一起发现问题; 开发人员在开发新功能过程中,可能会遇到之前存在的bug或者突然发现了之前没发现的bug,这时候应该要告诉测试人员跟进,而不是自己直接修掉。因为你以为的修掉并不一定真正没问题,一定要进行回测,同时留下记录,可能会给以后的追溯带来帮助; 其他: 团队每天开站会,目的在于描述自己的进度情况。一定要明确!要明确!要明确!如果不明确表述,其实等于没有开站会; 在适应新开发流程的初期,SM最好能够每天or每两天确认下组员们的真实开发情况,包括进度and需求理解上; 一开始尝试Scrum敏捷开发时,容易预估(目标、时间)不准确,导致2周一个迭代版本比较困难,可能会经常延迟。面对这种情况,我目前是倾向砍掉部分需求,先满足2周一个版本,让团队先形成这么一个周期惯性,再去优化惯性内的效率问题(也就是之后再提高目标的要求); Scrum要求是: 目标、质量验收标准不能改变; 完成目标的要求不能过低;(文末有相关资料) 关于如何解决这个问题,也还在摸索状态 T_T,大家如果有好的建议和想法,求沟通呀~ 开发后: 组员们要一定总结下这期开发中存在哪些问题,如何解决或者减弱这些问题的影响,不要流于形式。毕竟对团队来说,这是新的开发流程,不适应或者做的不好很正常,不要怕说不要的地方,大家在错误中磨合、改善、成长才是最重要的; 结合上一点,每期也要对上期提出来的问题进行回顾,看在这期中是否有改善这个问题。只记录不回顾,等于什么都没干; 以上,是目前的一些体会和总结,希望在不断实践中,能够得到新的解决方法和体会… 最后附Scrum的官方资料: 什么是Scrum? http://www.scrumcn.com/agile/scrum-knowledge-library/scrum.html Scrum团队的三个角色? http://www.scrumcn.com/agile/scrum-knowledge-library/scrum.html#tab-id-5 Scrum的三个工件? http://www.scrumcn.com/agile/scrum-knowledge-library/scrum.html#tab-id-6 Scrum的五个活动? http://www.scrumcn.com/agile/scrum-knowledge-library/scrum.html#tab-id-7 敏捷估算? http://www.scrumcn.com/agile/scrum-knowledge-library/scrum.html#tab-id-14 sprint? http://www.scrumcn.com/agile/scrum-knowledge-library/scrum.html#tab-id-15 每日站会? http://www.scrumcn.com/agile/scrum-knowledge-library/scrum.html#tab-id-16 完成的"定义"? http://www.scrumcn.com/agile/scrum-knowledge-library/scrum.html#tab-id-17