拥抱开发过程中的“黑天鹅”

简介: 6月29日,由阿里云研发协同RDC、阿里云云效和云栖社区联合举办的“首届阿里巴巴研发效能嘉年华”上,阿里巴巴资深专家、敏捷教练洪湖带来“拥抱‘黑天鹅’”的演讲。本文主要从黑天鹅事件开始谈起,接着分析了哪些模式是脆弱的,而后分享了通过案例得出了从变化中获益的启示,最后着重说明了打造敏捷组织的重要性。

6月29日,由阿里云研发协同RDC、阿里云云效和云栖社区联合举办的“首届阿里巴巴研发效能嘉年华”上,阿里巴巴资深专家、敏捷教练洪湖带来“拥抱‘黑天鹅’”的演讲。本文主要从黑天鹅事件开始谈起,接着分析了哪些模式是脆弱的,而后分享了通过案例得出了从变化中获益的启示,最后着重说明了打造敏捷组织的重要性。

 

直播视频点击观看

随着云计算、大数据、AI智能等前沿科技的发展,传统的研发速度越来越难满足企业快速发展的需求,研发效能也成了继商业模式、技术突破之后的另一核心竞争力。本文主要从黑天鹅事件开始谈起,接着分析了哪些模式是脆弱的,而后分享了通过案例得出了从变化中获益的启示,最后着重说明了打造敏捷组织的重要性。一起来了解下吧:

 

黑天鹅事件

在发现澳大利亚的黑天鹅之前,欧洲人认为天鹅都是白色的,但这个不可动摇的信念随着第一只黑天鹅的出现而崩溃。人们总是以自己有限的经验和不堪一击的信念来解释不可预测的黑天鹅事件。黑天鹅无法预测,我们应该做的是适应这种不可知的未来。

那么,产品开发中可能会碰到什么样的“黑天鹅事件”?

我们先来看看想做一个成功产品的背后会有什么样的假设呢?

假设1:找到了正确的问题;

假设2:产品被正确定义;

假设3:产品被正确构建;

假设4:做出来的产品可以解决问题;

假设5:有足够多的人愿意买单。

任何一个假设都有可能不成立,在得到最终验证之前,你没法预测假设是否成立。

既然黑天鹅事件不可预测,那就不要天真地试图预测,我们需要适应它们的存在。

怎样适应“黑天鹅”事件呢?《反脆弱》这本书中给我们介绍了两点:降低脆弱性和从变化中获益的能力。弄清楚什么是脆弱的,比预测对其造成伤害的某个事件是否会发生、何时会发生要容易得多。

 

什么是脆弱的

瀑布开发

7be5e03c80e6a263210ad9fde60775b5c727d913

在瀑布模式下:

如果产品目标错了,只有产品发布后才能知道目标错了。而目标是在我们掌握知识最少的时候做出的决策;

如果架构出问题了,也就是技术风险,可能要到后期测试时才会暴露,而我们在设计阶段,未写一行代码时就做出了最重要的架构决策;

同样地,还存在集成风险,大家开发的很多模块代码在开始测试时才开始集成在一起;此外还有需求变化、延期等······

总体来看,瀑布开发是很脆弱的,它很难应对黑天鹅事件,一旦发生,我们没办法及时响应变化。

传统项目管理

对于传统项目管理,我们会管理四个变量,范围、时间、成本、质量。大家都说质量很重要,它会影响我们长期的发展,所以质量不能牺牲。然后我们要确定范围,估算什么时候可以交付,以及需要的成本。

在规定的时间、规定的成本里,按照质量的要求,成功的交付了我们达成一致的范围,这就是一个成功的项目。

那么,如果这时发生了“黑天鹅”事件,我们会怎么办呢?

我们会采取一些秘密武器:例如Copy & Paste,可以快速的把功能实现出来,此外还可以减少测试、没有自动化、不重构和去掉同行评审等。

之所以会采取以上的一些方法,是因为质量具有滞后性,其它几个变量发生变化都是马上就会有反馈的。从而我们的系统开始变的混乱,到处是重复的代码。每次修改,我们都要祈祷别出问题,因为我们的代码容易出错,缺少自动化测试的保护。

b307d6e6b7858e2eb50f0f95d8d74a328a19921a

整个响应速度越来越慢,我们不断积累债务,忙于应付新功能,忙于修改BUG。

所以传统项目管理模式是脆弱的。

组件团队

现在比较多的团队是这样一种分工模式:一群开发按照各自的组件作分工,一个需求过来后,会把任务分配给各个人,各自负责一个模块。他们之间的工作量不会均衡,这时往往会同时启动多个需求,出现大量并发任务在进行的情况。

这时,如果某模块进展不如预期,所有需求都会受影响;如果出现有人离职、请假时,或者当需求发生变化时,都需要调整所有人的计划。

为此,有的组织会组建一个团队去负责某个模块,开发人员围绕软件模块组合成团队。这解决了问题了吗?并没有。

4c6bfd144e5294326aa8e9b9e775f9924d209de5

这种模式一定会导致瀑布式开发,当一个团队负责某一模块时,由谁来进行需求分析?由谁来完成高层设计?由谁来完成端到端的测试?由谁来做计划、协调?,都不是某个团队,这就需要有业务分析师分析好需求,需要一个架构工程师将架构做好,需要有专门的测试人员做端到端的测试,我们还需要优秀的项目经理,来贯穿协调。

如果中间发生任何变化,都会影响到其它团队,协调起来非常困难。

8b6668e5d02e16794826273f20b6963fafe81c3a

这种模式也会鼓励追求局部效率最优,当我们去看所有的需求时,假设有两个团队D和E,前面高优先级的需求与它俩都没有关系,它俩可能会启动新需求。而当它启动新需求时,需要与其它团队讨论,对其他团队造成干扰,反而拖慢整个开发进度。

因此,组件化分工、组件团队也是脆弱的。

高耦合的代码

9622672699086a454b878b9bf11b77857b83bf1d

图中反应的是内聚和耦合的关系,显然它是高耦合的。

  • 内聚:一个单位内部各种元素之间的关联紧密程度;
  • 耦合:两个或多个单位之间的关联紧密程度。

97030bd97780bb3f05745ab03609f2bcd726459d

高耦合会导致代码难以重用,加小需求可能需要修改N多个地方,随之可能会带来一些BUG。

因此,低内聚高耦合的代码是脆弱的。

总结

什么是脆弱的?

从流程角度来说,传统的瀑布开发、项目管理模式是脆弱的;

从技术角度来看,低内聚高耦合的代码、计划式设计、缺失自动化保护是脆弱的;

从人的角度的说,专业化分工、组件团队、竖井组织也是脆弱的。

 

从变化中获益

从变化中受益的关键之处在哪呢?我们可以从以下两个案例中得到启发:

米格-15 vs F-86军刀战机

e7de46360094e6fb8ec833b17157e2e1e21c3206

为什么处处占尽优势的米格-15会败给F-86军刀呢?

340a92d385e6c055d20e4c13fb11d5a73acab3ef

制胜的关键是不是绝对速度更快,而是比对手更快的完成OODA环。

小白鼠实验的启示

为什么用小白鼠?因为它的基因序列与人类很类似,繁殖快,生长周期短,且成本低。

6b8dcfe8bbe6ff08f14d6a9fb1c451efd64ace27

当我们面对不确定的“黑天鹅”事件时,从变化中获益的关键是:更快的、更低成本的学习循环,以更快的速度、更低的成本来验证假设、响应变化。

因此,我们可以给敏捷性定义:组织在不断变化和不可预测的竞争环境中应对变化和创造变化的能力,这就是我们要打造的能力。

 

打造敏捷的组织

那么,如何才能更快的速度、更低的成本 验证假设、响应变化?

小批量 à 短周期 à 快速反馈 à 响应变化

小批量

bc99b8553f940e6bdbbb674156086257f31e3481

小批量的背后是有理论支撑的,如果分析排队论,会发现批量以及资源利用率对周期的影响,随着批量和利用率的增加,周期会急剧上升,它不是线性的。

如何小批量呢?

b8311636266308ef1d10ea58dad7b2d8532316d5

将大需求拆分成小需求,然后按照优先级排序,进行开发。要避免按模块拆分。

fb2efc3b80626a8ae2838bfd62dd4d2a8732d5d2

我们考虑风险驱动和价值驱动去排序,先把高价值、高风险的东西完成掉,快速的获得这些反馈,才可能以更少的代价、更低的成本、更快速的获得收益。

很容易得出,迭代开发模式是更适合来应对黑天鹅事件。

技术支撑

演进式设计:原来可以完成所有的设计再开始写代码,现在要变成一种演进式的设计,不要去实现未来的需求,只做适度的预先设计并保持合理的设计状态,才可能在需要添加需求时轻松搞定。

e4d2a481435545b50d15eeb9c1ac051e378ed94e

改成小批量也不是没有代价的,随着批量越大,有些成本是会下降的,而有些成本是会增加的。敏捷开发许多技术上的实践恰恰是希望解决这些问题,如果我们能够在减小批量时不显著增加成本,我们就可以更好的应对开发变化。那么,哪些实践会帮助我们控制小批量的成本呢?

测试自动化

5b364341be1a63346bcb05a1ec96ce4fcd148975

我们需要构建分层的自动化测试体系,图中越向上,越接近业务,反应真实需求状况;越往下,越面向技术,成本更低、影响范围更小,发现问题定位起来更容易。我们需要分层的自动化测试体系支撑快速迭代模式。

持续集成/持续部署

9995c4cac4659423e9e4a63ba3e69d0f81958bae

工程师每修改几行代码,每完成一小点功能,我们就可以提交代码,触发自动化测试得到验证,才能快速地获得反馈,去保证软件一直处于可工作的状态,如果没有技术手段的保证,是没有办法用迭代开发模式的。

敏捷项目管理

1009a3ef4f72ee44ea96bf9086d5e47b6e3ee567

让范围成为变量。在开发需求分析过程中,坚持质量内建,在时间和成本的约束下,让价值产出最大化。

全功能团队

651afb3e41c8368e170eeee2573fa27356106ec4

在组织层面我们需要全功能团队,面向特性的自组织团队保证端到端的价值交付。一个需求的交流协作都是团队内部的交流协作,可以更快速的应对变化。我们更鼓励无差别的全功能团队,当需求发生变化时,可以很容易作出调整。

我们希望打造有一个敏捷的组织,从交付层面讲,用小批量、短周期方式更快地作迭代,用全功能的组织形式灵活地响应变化,同时,我们需要获得快速地反馈不断持续改进。

与其预测风雨,不如打造方舟!

相关文章
|
8月前
|
敏捷开发 运维 Devops
拥抱变化:软件开发中的敏捷思维
在快速变化的技术世界中,传统的瀑布式开发模式已不再适应市场的需求。本文探讨了敏捷软件开发的理念与实践,以及它如何帮助开发团队更灵活地应对变化,提升产品质量和客户满意度。通过分析敏捷的核心原则、实施策略以及面临的挑战,揭示了敏捷思维在现代软件开发过程中的重要性。
|
4月前
|
测试技术 UED 开发者
软件测试的艺术:从代码审查到用户反馈的全景探索在软件开发的宇宙中,测试是那颗确保星系正常运转的暗物质。它或许不总是站在聚光灯下,但无疑是支撑整个系统稳定性与可靠性的基石。《软件测试的艺术:从代码审查到用户反馈的全景探索》一文,旨在揭开软件测试这一神秘面纱,通过深入浅出的方式,引领读者穿梭于测试的各个环节,从细微处着眼,至宏观视角俯瞰,全方位解析如何打造无懈可击的软件产品。
本文以“软件测试的艺术”为核心,创新性地将技术深度与通俗易懂的语言风格相结合,绘制了一幅从代码审查到用户反馈全过程的测试蓝图。不同于常规摘要的枯燥概述,这里更像是一段旅程的预告片,承诺带领读者经历一场从微观世界到宏观视野的探索之旅,揭示每一个测试环节背后的哲学与实践智慧,让即便是非专业人士也能领略到软件测试的魅力所在,并从中获取实用的启示。
|
6月前
|
机器学习/深度学习 人工智能 监控
探索自动化测试的利与弊:软件质量保证的新纪元
在数字化时代的洪流中,软件测试作为保障产品质量的关键步骤,已从手动执行转变为自动化流程。本文深入剖析了自动化测试工具的优势与潜在缺陷,并通过实际案例分析,揭示了自动化测试在不同软件开发生命周期中的应用效果。文章旨在为软件测试专业人员提供一个关于是否及如何实施自动化测试的全面视角,同时指出了未来自动化测试可能面临的挑战和发展方向。
48 3
|
5月前
|
运维 监控 安全
运维之道:从混乱到秩序的旅程
【8月更文挑战第15天】在数字化时代的浪潮中,企业运维管理的重要性日益凸显。本文将探讨如何通过有效的策略和实践,将运维工作从一片混沌转变为有序可控的状态。我们将深入分析现代运维面临的挑战,并提出一系列解决方案,旨在帮助运维团队提高工作效率,确保系统的稳定性和安全性。
39 0
|
7月前
|
敏捷开发 开发者
拥抱不确定性:软件开发中的敏捷思维
【5月更文挑战第37天】 在快速变化的技术世界中,不确定性已成为常态。本文探讨了如何通过敏捷思维来拥抱这种不确定性,提高软件开发的适应性和效率。通过分析敏捷方法论的核心原则,我们将了解如何在项目开发过程中灵活应对变化,优化团队协作,并持续改进产品。文章将强调在不确定性环境中,敏捷思维如何转化为竞争优势,以及如何在日常工作中实践这一思维方式。
|
8月前
|
敏捷开发 持续交付 开发者
拥抱变化:软件开发中的敏捷思维与持续学习
【4月更文挑战第30天】 在快速迭代的软件开发领域,"敏捷"不仅是一套方法论,更是一种哲学。本文将深入探讨敏捷软件开发背后的核心原则及其对开发者心态的影响,特别强调持续学习的重要性。我们将剖析如何在不断变化的技术环境中保持适应性和竞争力,并提出策略以促进个人和团队的成长。文章旨在为读者揭示那些成功适应行业变革、不断提升技术栈并保持职业生涯活力的专业开发者所遵循的实践方法。
|
8月前
|
开发者
拥抱不确定性:在软件开发中实践敏捷思维
【4月更文挑战第27天】 在不断变化的技术领域,不确定性是一种常态。本文探讨了如何在软件开发过程中采用敏捷思维来应对和利用这种不确定性。通过分析敏捷方法论的核心原则,我们将了解如何通过迭代开发、持续反馈和适应性规划来增强项目的灵活性和响应性。文章将提供实用的策略和实例,帮助读者在技术项目中实施敏捷思维,从而更有效地管理复杂性和变化。
62 2
|
8月前
|
开发者 UED
拥抱不确定性:软件开发中的敏捷思维与持续学习
【5月更文挑战第29天】 在快速变化的技术世界中,不确定性已成为常态。本文探讨了如何在软件开发实践中运用敏捷思维来适应和利用这种不确定性,以及如何通过持续学习保持个人和团队的竞争力。通过分析敏捷方法论的核心原则,我们揭示了它们如何帮助开发者更好地应对需求变更、技术演进和市场动态。同时,文章还将讨论持续学习的重要性,以及如何通过实践驱动的学习来不断提升技能和知识,从而在不断变化的环境中保持领先地位。
|
8月前
|
敏捷开发 测试技术 持续交付
拥抱不确定性:软件开发中的混沌与秩序
【5月更文挑战第20天】在软件工程的领域,不确定性是一种常态。本文探讨了如何在看似混乱的开发过程中寻找秩序,通过具体实践和技术方法来管理和利用不确定性。我们将分析敏捷开发、持续集成、自动化测试等技术如何帮助开发者在快速变化的环境中保持灵活和响应性。同时,我们也将讨论混沌工程的原则,它教会我们如何在不可预测的系统行为面前构建更加健壮的软件架构。
|
8月前
|
敏捷开发 安全 测试技术
拥抱不确定性:软件开发中的敏捷思维与实践
【4月更文挑战第17天】 在快速变化的技术世界中,不确定性已成为常态。本文探讨了如何在软件开发过程中应用敏捷思维来应对和利用这种不确定性。通过分析敏捷方法论的核心原则,我们揭示了它们如何帮助团队更灵活地响应变化,提高产品质量,并最终实现持续交付。文章还将分享一些实用的敏捷实践技巧,以及如何在团队中培养这种思维方式。