写点什么

无意识的敏捷?(敏捷开发的节拍)

  • 2008-02-14
  • 本文字数:1174 字

    阅读完需:约 4 分钟

AI 大模型超全落地场景&金融应用实践,8 月 16 - 19 日 FCon x AICon 大会联诀来袭、干货翻倍!

Damon Poole 最近在博客上写到,我们中有很多人可能正在实践敏捷开发而不自知。

有趣的是,大多数的软件车间都是无意识的追随着敏捷开发的步伐。他们定期的进行发布,这种做法跟敏捷团队的做法很相似,不过他们却没有意识到这点,并因为不得不这样做而感到羞愧。随后,他们就希望不要再这样来一次了。

大多数的团队都是什么时候做的像敏捷开发一样呢?即使他们不是敏捷的

我指的是维护版本、补丁和热修复。别去想它们本来是不必要出现的——其根由是源自于“一次大型发布”出现的问题——而且还是在紧张的压力下完成;也 别去想有时候你必须要用另外一次热修复来重新做一次先前的热修复。第二次热修复的需要通常是在第一次热修复余波未息时,经过紧张研究发现的,根源在于热修 复大概根本就没有走过一个正常 QA 过程的完整循环。

这种事情,我们每个人应该都听着挺耳熟的,即便我们没有实施敏捷……有趣吧——不是吗?Damon 的重点在于,我们中大多数人在事情发生后感到羞耻并下决心不再让它重新发生,这种事应该是挺普遍的。为什么呢?

我相信大多数软件车间向前走一小步然后又远离敏捷开发的原因是,这种行为本身就是软件开发的自然节拍,人们很难与之相抗。要维持下去并非易事,你需 要做到两点:深入理解敏捷,和有意识地去控制。如果不是有意识地打算这样做,也没有短期迭代的同步信号,那么除非你在这条路上呆了很久,否则就很难注意到 是否走错了路。另外一个问题是,如果一个组织中的每一个人都纯粹碰巧的和敏捷节奏发生了同步,那么项目计划、习惯和已经确立的过程所发出的同步信号就会和 自然节拍发生冲突。这种情况下,自然节拍就不会再有机会东山再起了。

所以,节拍也是敏捷开发取得成功的核心要素之一——它会让人精疲力尽(但它也非常有效)。这和其他人所做的有关敏捷软件开发的报告中的观点正相吻合。在 Rhythms as Agile Diagnostics 一文中,作者首先发明了这个观点。文章说道,判断你是否走在敏捷开发的正途上的一种方式就是看一下项目中的主要节拍:

健康的敏捷项目有多种典型的节拍,如发布、迭代、站立会议、由持续集成启动的构建,还有开发人员的红 - 绿 - 红测试循环。这些节拍有着很正常的范围 (如站立会议不多于 15 分钟)和特征(在站立会议中不包括设计讨论)。如果它们超越了正常的范围,或是显示出来的特征出现了偏差,这就表示在敏捷过程中出 现了问题。医生会根据病人的脉搏或是血压来判断病人是否生病,我们通过检查节拍来判断敏捷过程中是否出错。当节拍出了问题,有时候需要被直接处理,有时候 需要我们对过程进行深入分析,找出并修正问题的根源。

这种有关节拍与敏捷开发的观点跟你的过往经验相符么?你或你的团队是否曾经无意识地实施过敏捷?如果你已经在实施敏捷,或者正在采用一些实践,那你目前的项目中有哪些节拍呢?

查看英文原文 Rhythms of Agile Development: Unconsciously Agile?

2008-02-14 00:07895
用户头像

发布了 197 篇内容, 共 53.2 次阅读, 收获喜欢 20 次。

关注

评论

发布
暂无评论
发现更多内容

JVM进阶(二):初识 JAVA 堆

No Silver Bullet

Java JVM 内存 2月月更

守护石谈学习Java之路

DaemonStone

Java 学习方法 经验分享 编程学习

共赴冰雪之约,见证体育场馆的数字化之旅

脑极体

也谈一下Web3.0-01

wood

300天创作 Web3.0

【以太坊剖析】以太坊虚拟机(EVM)之基本定义

起航

区块链 以太坊 EVM 以太坊虚拟机

Netflix是如何做决策的? | 1. Netflix的决策制定

俞凡

数据分析 netflix 大厂实践 2月月更

WebRTC 传输通道的建立过程解析 | 社区征文

liuzhen007

音视频 新春征文 2月月更

2021考了个PMP

夏兮。

PMP Certification

使用 React、Solidity 和 Web3.js 构建真实世界的 dApp

devpoint

dapp React Solidity Web3.0 2月月更

以太坊剖析 - 交易收据(TransactionReceipt)

起航

区块链 以太坊

Jvm 参数默认值

努力努力再努力

在线SVG在线编辑器

入门小站

工具

视频绿幕抠像一键搞定,这些好用工具你要知道。

彭宏豪95

效率 工具 视频剪辑

图解MySQL(5)-Buffer Pool的flush链表

JavaEdge

2月月更

《卡片笔记写作法》读书笔记 - 重新认知思考和写作

懒时小窝

读书感悟 读书总结

精度丢失问题

编程三昧

2月月更

以太坊剖析 - 区块头部(BlockHeader)

起航

区块链 以太坊

Netflix是如何做决策的? | 2. 什么是A/B测试

俞凡

数据分析 netflix 大厂实践 2月月更

第七节:SpringBoot高级属性配置二

入门小站

springboot Java EE

JVM进阶(三):内存分配与回收策略

No Silver Bullet

Java JVM 内存分配 2月月更

对 HTTP 缓存的全面总结

编程三昧

缓存 前端开发 HTTP 2月月更

Firefox 登录后无法同步书签

TroyLiu

firefox 工具 浏览器 数据同步 书签

《恰如其分的软件架构》随笔一:模型是解决复杂问题的重要途径

panda

模型

以太坊剖析 - 交易执行(TransactionExecutor)

起航

区块链 以太坊

[架构实战营] 模块八作业

Geek_0ed632

「架构实战营」

开源效能可视化平台介绍 -DevLake

夏兮。

效能平台 MARI

【技术】谈ServiceMesh落地的三大难题:选型、过渡、多集群

极光一号。

云原生 servicemesh 服务网格 应用交付

Netflix是如何做决策的? | 3. A/B测试结果之假阳性和统计显著性

俞凡

数据分析 netflix 大厂实践 2月月更

如何写好代码注释?

蜜糖的代码注释

Java 后端 开发 2月月更

架构训练营 week8 课程总结

红莲疾风

「架构实战营」

以太坊剖析 - 区块(Block)

起航

区块链 以太坊

无意识的敏捷?(敏捷开发的节拍)_研发效能_Amr Elssamadisy_InfoQ精选文章