继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

无尽Scrum的替代方案

慕丝7291255
关注TA
已关注
手记 281
粉丝 15
获赞 70

Scrum 是一种广泛用于开发和交付数字产品的流行方法。最常见的 Scrum 形式是一系列不断耗尽精力的冲刺,没有为如持续研究这样的长期投资留出空间。不一定非得这样。Scrum 可以带来能量,而不是消耗它。

Header image: title + an infinite amount of circular arrows symbolizing ‘endless scrum’

我们从一个例子开始吧:

乌塞恩·博尔特是一位不可思议的短跑选手。看他参加100米短跑,就像看到超人飞行一样。他跑起来轻松自如。如果我们让他跑马拉松,他可能会把记录缩短一半。继续冲刺吧,乌塞恩!

想象一下如果我们向博尔特先生提出这样的想法;这位世界冠军最有可能的回答会是:“这样做不仅愚蠢而且危险,你如果继续这样跑,可能会有生命危险”。

事后看来,这样的结论是合乎逻辑的。

为什么大多数公司都在没完没了地冲刺?

在这篇文章中,我会列出为什么连续的冲刺周期是个坏主意的原因,以及你可以尝试的三种应对策略来解决这些问题

你再这么拼命跑下去,就会死
—— 假想中的尤塞恩·博尔特,2024年9月

1. 无尽的冲刺会把你累死

一种流行的产品开发方式是敏捷开发,而最流行的方法是scrum。我合作的所有公司都在某种程度上使用 scrum;要么严格遵守规则,要么宽松使用,或者使用像 SAFe 这样的复杂框架(感到反感)。

对于我经历的所有Scrum变体而言,一个基本的原则是,一个sprint结束,另一个就开始了。永无止境的冲刺。

无休止的冲刺导致了几个相互关联的问题:团队士气下降,质量下滑,脱离实际业务,以及不切实际的预估。

你是否在公司中发现下面这些问题中的任何一个?
(让我们在Medium上做一个小投票:在你遇到的问题上做标记或评论)

1.1 过于理想化的估算
  • 故事很难评估:需求和验收标准不够清晰
  • 令人惊讶的是,团队抱怨需求和验收标准定义得太死板了,由于缺乏灵活性而无法发挥创造力来创造最佳解决方案
  • 由于不确定性,团队往往会高估。这导致利益相关者寻找捷径,例如移除争议较大的需求项
1.2 与其他业务的距离
  • 业务相关方发现很难把需求放进开发环节,开发功能需要很长时间,最终结果与他们的预期不符。不知道具体该说明些什么。
  • 相关方过度要求,因为他们要等待很长的时间才能再次轮到他们,这反而加重了其他人的负担。
  • 研究和开发之间存在差距。研究人员难以将他们的发现传达给开发团队,而开发团队则感觉像是在没有了解用户需求的情况下盲目进行开发。开发人员没有时间参与像可用性测试这样的研究会议。
1.3 失去动力
  • 任务从一个冲刺溢出到另一个冲刺:产生僵尸任务,跟随团队经历多个冲刺
  • 团队停止庆祝重要里程碑,因为他们总是在为下一个事情忙碌
  • 开发者发现很难将用户故事纳入冲刺中以解决重要问题,如架构更新、单元测试、重构、改进现有功能或仅仅是“思考时间”——因为总是被“业务”要求开发“新事物”所吸引
  • Scrum 团队成员在描述工作时会谈到“苦工” 😿
1.4 质量下滑
  • 因为超出了预期和 sprint 结束时的压力,带着未修复的 bug 发布功能,这样会导致返工,也就是过去 sprint 留下的问题
  • 一旦完成,很难迭代功能来纳入学习成果,为最终用户提供最佳影响,因为待办事项列表已经被即将处理的事项填满
  • 在 sprint 过程中获得的学习难以应用,因为开发人员正在处理几个月前创建的故事(和设计)
1.5 有关程序争辩和相互指责

上述问题导致了程序上的争论和推卸责任。有些问题不够重要,有些问题又太小,需要更细致的打磨和完善;设计不应该在一次冲刺中频繁变动,我们需要更灵活地适应变化;沟通不足,会议过多;“业务方”不太理解等。

这可以解决,但先有个问题。

2. 有些事情急不了,比如说持续的研究工作这种事。

除了连续冲刺带来的破坏性问题之外,还需要指出一个重要的事实:《并不是所有的活动都适合Scrum这种方法》。

Scrum 需要精准估量的故事。但是这种要求无法满足研究、设计和 IT 架构中的开放式问题。那些需要对齐、反复思考、长期思考和灵活实验的问题。Scrum 并不是为此而设计的。当然,我们可以将这些活动“硬塞”进 Scrum 流程中,通过设置时间限制的冲刺,或让故事跨越几个 Sprints,但很少真正奏效。

在一些公司中,将这种类型的工作放在开发冲刺之外进行,采用非 scrum 的过程,或者相同节奏的并行冲刺。这会在组织中制造孤岛和隔阂,尽管 scrum 的力量在于多学科团队的协作。

我们可以解决所有这些问题,但在介绍我的方案之前,我们还需要一块额外的拼图。

3. 全天 scrum (敏捷开发)是误导

一个 “为期三周的冲刺,有8个全职员工” 听起来非常棒,这相当于320个小时的纯开发时间!

难道是吗?

当然不是,绝对没有。没有人每个冲刺周期每周都花40小时编写用户故事。

人们需要休假。他们进行培训。去参加行业大会。参加公司会议。参加Scrum仪式(站会、梳理、回顾)。带生病的猫去看兽医。去看牙医。开会。读研究报告(开玩笑)。在Slack上回答“快速问题”却花了几小时。参加更多的会议。还有(天啊!)喝咖啡聊天气。

这些事情本身并没有什么不好或邪恶。大多数提到的事情都有助于一个好的工作环境。我们可不像机器人。还不是。

Scrum承诺我们的冲刺周看起来是这样的:

A calendar showing two weeks. In it are the main scrum rituals \(standup, planning, review, retro\) and all other time is allotted to ‘work on tickets’

但实际上,我们的周看起来更像这样:

Same calendar as before, but now meetings have been inserted, reducing the amount of time on ‘work on tickets’

那太乐观了,我猜你一天得开好几个会吧!

情况更糟糕了。如果我们一直被打断,就无法专心。每次被打断,都需要重新集中注意力。一个人通常需要大约15分钟才能重新集中注意力。四次30分钟的会议会额外损失整整一个小时的专注时间!

Third iteration of the calendar. Each block of ‘work on tickets’ after a meeting now has time taken off of it symbolizing ‘time lost to context switching’

除此之外,打断还影响了合作的可能性。要是我们一整天都在开会,你一半时间,我另一半时间,我们怎么能够一起工作呢。

如果我们把这些团队成员的日程排在一起看,就会发现他们一起处理工单的时间是有限的。

Fourth iteration of calendar: blocks of ‘work on tickets’-time are split into “solo work” and “overlap with team”.

那看起来真是糟透了。但是别担心,解决办法很快就会来了!

我们一直在挖的这个大坑,来个快速回顾

Scrum承诺聚焦、责任感、持续改进和协作精神。但实际上我们得到的是:

  • 没有冲刺团队内外的人之间的合作
  • 非冲刺干扰导致无法集中精力
  • 团队内部合作缺失,因成员遭遇不同干扰
  • 不适合冲刺的活动(比如持续研究)要么搁置,要么单干,要么被迫套用“用户故事”格式
  • 没有持续改进,因为繁重的工作让人难以跳出框架思考
  • 无尽的冲刺让团队成员感到失望和恐惧

够了吧,咱们快点爬出来吧!

摆脱无尽Scrum的方法

是的,我正在将这篇文章的标题作为副标题重复使用。让我们来看看三种替代无尽Scrum的方法。

首先,让我简单介绍一下自己。我不是反对 Scrum 的人。在我之前是出色的战略产品设计师(现在是自由职业者)——您可以在领英上联系我(https://www.linkedin.com/in/matthijs-zwinderman/)。我在几个项目中当过Scrum 主管。我见过这种方法有效。

当 Scrum 真的管用时,它会变得神奇。一个多功能的团队,成员平等。完全一致的目标。全速前进。看着产品在你眼前成形。激动的泪水不禁涌出,你对人性的信任得以重燃。好吧,也许我不是指那一点,但请相信 Scrum 确实能管用,甚至可以(惊不惊喜)变得有趣。

我们怎么去那儿?

方案1:scrum-days

Scrum手册里没有说Scrum是全天候的工作。过程中的仪式确实带来了很多繁琐的步骤,因此理论上讲,每天都全力以赴投入Scrum确实说得通。但实际上,这通常会带来前面提到的问题。

我们可以把一周分成“Scrum日”和“非Scrum日”。每个团队成员只需在一周中的“Scrum日”工作两到三天。

听起来一周三次的 Scrum 比你习惯的五天少了些,但先听我说一下。

Scrum日是什么样的?

在这段时间里,在“冲刺阶段”期间,处于“冲刺”状态的人需要遵守严格的“仅冲刺”规则。团队之外的人不得在此期间召开会议或打扰他们提出快速问题,团队成员也不会安排任何非冲刺活动。

这确实很苛刻。但是好处是压倒性的。由于缺乏“外部干扰”,Scrum团队成员们可以连续三天专心致志地工作。没有分心的事,没有任务的切换,团队成员们全天候在一起。这几天里,你就能拥有一支专注、合作且多功能的团队。

公司里的其他同事将需要适应“冲刺日”期间的信息和会议管控。然而,奇怪的是,他们在“非冲刺日”会有更多机会与冲刺团队一起工作。

非敏捷开发的日子(非Scrum日)

‘非Scrum的日子’就是一般人所说的‘普通日子’。这些日子是在开会、简短通话、一对一、培训、知识分享、做用户研究、参加研讨会、进行团队建设等等。

而现在,Scrum团队成员也能享受到这些好处了。他们可以有足够的时间来进行长时间的会议和深入思考,进行激烈却富有成效的工作坊,而不用担心冲刺结束的压力。

研究人员可以与开发者合作。测试人员可以花时间改进他们的自动化工具。设计师可以专注于长期深入的研究。架构师可以绘制白板并与利益相关者讨论。

Scrum 日子里,团队有了更多时间来完成任务,以及更多时间来处理其他任务。

实践中的敏捷日

关于“冲刺日”的描述,可能听起来有点太乐观了。

我们来看一个例子。看看当我们引入“冲刺日”后,我们的日历会怎样:

Monday, Tuesday and Wednesday are now ‘scrum days’. All scrum-related rituals are on these days, and the remaining time is all ‘overlap with team’. All meetings and other interruptions are moved to Thursday and Friday. There is time left-over on these days for other activities.

我只是重新安排了一下。我没有删除任何会议,也没有缩短它们,我所做的只是对Scrum日进行了组织。细心的读者会注意到,单独处理工单任务这一项已经消失了。这一部分已经被团队合作所取代。

如果我们考虑到上下文切换,新的“冲刺日”实际上只占了之前处理任务时间的超过95%。在理论上,这是一天最多两次会议的例子。五天的工作被压缩到了三天。实际上的好处更大,有时候甚至可以更大。(你有没有哪天会议少于两次的时候?)

当我作为Scrum主管时,我们是这样运作的。开发人员和测试人员每周有三天进行Scrum,而设计师、研究员和产品负责人则每周两天。我是一个严格的Scrum主管,不允许做任何与故事无关的工作。我甚至物理上将团队隔离,让他们在不同的地点工作。

我们度过了美好的时光。在冲刺日,设计师和开发人员一起处理细节。在非冲刺日,开发人员与设计师一起关注大局,并进行研究工作。产品负责人在冲刺日总是可以迅速做出决策,而非冲刺日,则有充裕的时间与其他成员保持一致。

团队合作非常好,速度也快得惊人。

我们做到了移山这样的大事,因此Scrum 日的工作进展得非常顺利。

另一种选择:Scrum框架下的假期

即使在没有冲刺日的日子里,团队也会因为高强度的工作压力持续不断而感到精疲力竭。

简而言之,无冲刺的日子有助于保持团队健康,但要发挥最佳表现,还需要更充足的能量补充。

我给你介绍一个叫做“Scrum假期”的概念:每个两到三个冲刺后放一周假。这听起来简直疯狂。甚至比完全不使用Scrum的日子还要疯狂。但这种方法确实管用。

为什么?嗯,当团队专注于任务并付出最大努力时,Scrum 效果最好。在这种情况下,一个两周(或三周)的冲刺可以交付大量产品。这正是Scrum爱好者们常说的例子!但这需要一个充满活力和热情的团队来完成,而不是一个被连续冲刺压垮的团队。

Two sprints with battery slowly draining. Then a break with a recharging battery. Then a third sprint with fully charged battery.

在冲刺假期期间,您的团队可以专注于偿还技术债务,探究问题的根源,或进行用户研究。

当我还是Scrum主管的时候,我们以两轮冲刺为一个周期工作。每个冲刺都有一个特定的目标:一个大型功能或“史诗级特性”,或者故事之间的某种共同主题(例如,“寻找并修复错误”,“无障碍性改进”)。完成那个目标成为了我们健康的目标——并且当我们达成目标时,那种喜悦的胜利感令人振奋。鼓励大家在工作时间内尽力而为(作为这个Scrum主管,当然不允许不健康的加班)——以及当我们实现了这些雄心勃勃的目标时,我会在冲刺评审会上用美食和饮料庆祝胜利。

那个团队给力。我们在五个冲刺周期内,六个人就搞定了这个复杂的项目。这种项目通常至少需要一年时间。

你不能连续不断地冲刺。

休息一下能提升工作效率。

(提到泰勒,他在20世纪初就证明了这一点))

另一种选择:更灵活地想问题 🙈

在本书的开头部分,我提到Scrum是一种敏捷工作方法。它并不是唯一的敏捷工作方法。

存在看板(Kanban)、形变法(Shape-up,由Basecamp的方法)、精益(Lean)、水晶法(Crystal)、特性驱动开发法(feature-driven)、动态系统开发法(Dynamic Systems Development Method)等,等等。

或者你可以选择自己动手创建一种流程,而不是遵循预定的方法。根据团队和具体环境的需求进行调整。尝试新事物,保留有用的,放弃没用的(了解更多戴明的文章可能会有所帮助)。

敏捷宣言是由四位顾问在滑雪度假期间撰写的,作为对他们所经历的不同流程之间相似性的总结。该宣言庆祝多样化的做法和灵活性,不相信僵化的框架:

我们重视的是:
- 个体和交互重于流程和工具
- 可运行的软件胜过详尽的文档
- 与客户的合作胜过合同谈判
- 应对变化比遵循计划更重要

每个公司在不同的环境中运作,公司内部的各个团队也有各自的需求和优势。没有一种现成的方法能完全适用所有公司,也没有一种方法能适合所有团队。

真正的敏捷性意味着学习、理解、实验,然后调整你的流程和方法(等等),使过程更加灵活。

结论

Scrum 可以很有趣,也能让人充满活力。可惜的是,但大多数公司在实践中并未如此。

我介绍了三个简单的步骤,帮助你从无休止的冲刺中解脱出来。

  • 引入Scrum日:让团队重新聚焦 同时 扩展与团队外部的协作
  • 引入Scrum假期,让团队充电,使Scrum再次变得有冲击力
  • 对工作采取更灵活的态度,而不是固守既定流程。借鉴其他方法,从 其他方法 中学习,尝试各种方法

最后提醒一下:你所引入的任何更改都需要时间才能生效,并且会有一些影响或波动。需要经历一个学习过程。不要仅仅试了两周就停止实验,也不要一次性引入太多改动。

祝你好运,希望你玩得开心,实验顺利!

期待听到您的想法:留下评论,或在领英上联系我

打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP