开发一个产品的新增量(也称为最小可行产品,MVP)的团队往往面临着艰难的处境:他们必须在很短的时间内开发和交付他们希望其能有价值的产品增量。他们还需要为这个 MVP 开发一个最小可行架构(MVA),以满足其质量目标——也称为质量属性要求(QAR)。
这两种力量之间的这种紧张关系造成了一个两难境地:团队是依赖久经考验但可能无法完全满足其需求的技术,还是探索可能更适合,但实施起来风险更大的新的和陌生的技术?团队及其组织如果一直坚持使用久经考验的技术,往往会在短期内将风险降至最低,但从长远来看,继续使用不再适合应对组织所面临挑战的那些旧技术会增加风险。
技术雷达是描述技术采用风险的一种流行方式
技术雷达(TR)是组织汇总和交流其在使用各种技术时所获得的经验的一种方式,如图 1 所示。
图 1:Thoughtworks 的一个技术雷达示例
在这个流行的表示中,技术雷达在一个圆圈的象限中显示了四个不同的技术领域,当然这里的技术领域可以多放一些,也能少放一些。在这个圆圈内,根据编制者的经验,需要建议团队是否应该:
组织对风险的亲和力也会影响技术决策,如图 2 所示。
图 2:技术采用因团队技能和风险承受能力而异
这张表使用 Everett Rogers 的创新扩散模型将技术成熟度映射到了组织风险承受能力上。从这个角度来看,如果你的团队认为在构建某个 MVA 时使用某种特定技术会很有用,你需要问自己“我们的组织是否符合该技术采用者的形象?”例如,如果你想使用自动机器学习(AutoML)技术,那么你的组织是否真的符合“创新者”形象?你的组织能否吸引精通该技术的人才?当这些实验可能没有回报时,你的组织是否依旧愿意进行实验?
每次产品发布都是或应该是一个实验
在上一篇文章中,我们谈到了每次产品发布都是一个增量式最小可行产品(MVP),它有着对应的最小可行架构(MVA),可确保 MVP 的价值能够长期维持。在这个模型中,每个 MVP 都是一个探索那些客户认为有价值的东西的实验,每个 MVA 都是一个关于如何可持续地支持该价值的实验。
这些实验为团队提供了尝试新技术的机会;为了实现发布的目标,团队可能必须使用一些新技术。他们面临的挑战是平衡技术实验和业务实验。业务利益相关者不会接受仅由技术实验组成的产品版本,如果技术实验失败,他们也可能会担心新版本将业务实验置于风险之中。团队必须协商解决这一问题。
但是……技术实验可能是实现业务实验所必需的。有时业务实验可能会失败并拖累技术实验,但如果技术实验不能满足迫切的业务需求,它也永远不会成功。
无论如何,如果团队想要在发布版本中加入技术实验,就需要与业务和运营利益相关者进行富有挑战性的讨论。业务利益相关者必须以他们熟悉的方式了解技术实验的好处,了解该技术如何更好地满足客户需求。
运营利益相关者需要确信该技术是稳定且可支持的,或者至少稳定性和可支持性是用于评估该技术的一部分标准。
完全避免技术实验通常是一件坏事,因为它可能会错过以更好的方式解决业务问题的机会,从而导致解决方案的效果不如其他方法。随着时间的推移,这可能会增加技术债务。
正如我们在最近的一篇文章中所写,承担技术债务(TD)是一种学习事物的方式,可以让你避免对那些你可能尚未完全理解的问题的解决方案做过度投资。在引入新的、不熟悉的技术作为 MVA 的一部分时,有意承担 TD 可能不是一件坏事。假设新技术成功满足了团队的需求,使 MVA 达到或超过其 QAR;这也可能适用于试图解决类似问题的其他团队,因此增加的 TD 可能不需要“偿还”。
但如果新技术未能兑现承诺,无法满足团队的需求,则应迅速终止实验,从而消除 TD 问题。这里的危险在于,你也许会假设在新技术上花费更多时间和精力可能会扭转局面。一旦确定 MVA 无法满足其 QAR,就应立即终止实验,无需在实验上花费更多时间和精力。小心落入“确认偏见”陷阱!
此外,如果实验规模太大而不能失败,或者实验失败会被视为坏事,那么它就不是实验。只有在实验没有提供任何有用信息的情况下,它才会是失败的;你要记住,一项技术,甚至一项特性就算没有提供预期的结果也并不是失败,你只是获得了相关信息而已。
团队在这方面犯的一个错误是,在不知道技术是否会产生预期结果的情况下,投入过多精力实施新技术。当他们不确定时,他们应该将发布分解为一些较小的版本,以便更快交付,从而获得反馈。
同样,开发团队及其业务利益相关者都应避免对价值做出假设,而是将复杂而昂贵的解决方案分解为一些较小的部分,这样他们就能更快、更轻松地进行评估。换句话说,如果“实验”太大而不能失败,那么他们需要将其分解为一些较小的实验。
平衡业务风险与技术风险
团队及其利益相关者首先必须就 MVP/ 新版本发布的业务范围达成至少是初步的协议。达成协议后,开发团队必须做出预测,判断他们需要做多少工作才能实现发布目标。这里他们就必须开始做出技术选择了,因为不同的技术会改变团队需要做的工作量和性质。
使用图 1 所示的技术雷达,团队将首先调查“采用”类别中列出的技术,并评估这些技术是否有某些选项可以帮助他们实现发布目标。如果他们只需要使用“采用”类别中的技术,他们的工作通常会更简单,风险更小。不过,这些更“成熟”的技术并不总是能完成团队需要做的所有事情,因此他们可能需要考虑“试用”类别中的技术,等等。
在做出这些决策时,团队会权衡各种技术风险,如图 3 所示。
图 3:团队权衡多种技术风险
这些权衡受到两个简单事实的制约:开发团队没有太多时间获取和掌握新技术,且他们不能因为采用未经证实或不可持续的技术而将新版本的业务目标置于风险之中。这通常会导致团队坚持使用久经考验的技术,但这种策略也存在风险,最明显的是锤钉式风险,即团队无论如何都会使用不适合新问题的旧技术,例如使用关系数据库来存储类似图形的数据结构。
设计有效的实验有助于团队平衡风险
任何新版发布的第一步规划工作是就发布的目标达成一致。关于这一点,最重要的决定是就团队或组织需要多快获得实验反馈达成一致。为此,他们需要了解应运行哪些实验。他们总要平衡至少两种实验:
对于每一种实验,团队及其利益相关者都需要就如何判断实验是否成功达成一致。此外,如上所述,如果实验规模过大或数量过多,团队及其利益相关者将需要缩小发布范围,以保持在新版本的反馈周期目标之内。
总结
开发 MVP 的团队只有很短的时间来开发和交付他们希望有价值的产品增量,以及创建 MVA 来支持该 MVP。他们可以依赖久经考验的技术,但这些技术可能无法完全满足他们的需求,也可以探索可能更适合但会增加技术风险的新的和不熟悉的技术。技术雷达是一种描述这种风险的流行方式,可以帮助团队对他们正在构建的解决方案及其相关的 MVA 进行实验。
产品发布是对团队提供的价值以及解决方案的可持续性而做的实验。这些版本发布应着眼于尽可能学习经验,而不是特性数量或交付的技术深度。发布中体现的实验必须以业务利益相关者和开发团队可以理解和支持的方式来平衡业务和技术风险。
实验规模过大或次数过多的版本会变得“大到不能倒”,不再是实验。快速和早期的反馈非常关键,可以防止过度投资于客户或用户不想要或不需要的东西,还可以防止产品架构变得臃肿和无效,并防止依赖不可持续的技术。
原文链接: