写点什么

从敏捷工程实践中获益的五种途径

  • 2014-07-17
  • 本文字数:4281 字

    阅读完需:约 14 分钟

创造有用的软件是门工艺。这是没有非黑即白的成功公式的。但是,却有一些敏捷工程实践,实践证明它已经屡次为企业增加了价值,但前提是要考虑周全之后再使用。在本文中,我将与大家分享 5 条具体的途径,你的企业能够通过这些途径从敏捷工程实践中获益。

(假设我们使用 Scrum + 极限编程(XP)= 敏捷这条基本公式,那么在我讲敏捷工程实践时就会谈到公式中与 XP 相关的那一部分,比如测试驱动开发、结对编程和持续集成。)

James Shore 在一篇精辟的博客中说:

_“_与 XP(极限编程)相比,Scrum 更加简单,对原有工作几乎也产生不了多大的影响,所以我看到很多人是从 Scrum 开始入手的。但其中的问题是,从 Scrum 开始入手的团队比从 XP 开始的团队多得太多了。XP 团队在开始时会经历更多的痛苦,但在第一年就会达到高效的状态。”

我不仅同意他所说的,而且也亲眼见过很多次这样的情况。XP 很难。它难在需要严格的纪律,另外,它的好处虽多却有时难以立杆见影。

我的父亲是一名牙科医生。他有一次告诉我说“找一位好的牙科医生是很难的。牙医能补牙或者杀死牙神经,但你 5 年内不会知道他做得好不好,因为你需要一段时间之后才知道他补得到底好不好。”XP 与之非常类似。

我清楚最好的软件开发人员(而且知道上千名)在高压环境下是最遵守纪律的。

许多开发人员体验了敏捷 /Scrum/ 精益 /XP 的做法。但是,严格的截止日期临近时,或者团队已经拖期时,再或者公司要求团队“快速完成”时,他们还能维持多高的纪律水平呢?

There are many XP practices. The most valuable ones for a business are:

现在有很多 XP 实践,其中对商业而言最有价值的是:

  • 测试驱动开发—TDD 是你的商业安全网。因为测试是在编码之前完成的,所以写完的测试一定会运行失败,接下来再写代码使测试可以通过。TDD 保证你的产品功能,不管公司和技术团队实现的是大规模的变更还是小规模的变更。
  • 结对编程—让 2 名开发人员写同一段代码,使用同一个键盘和同一台显示器。因为结对大大降低了浪费的时间和缺陷,所以能带来更高质量的代码,并带来高水平的协作。
  • 集体代码所有制和持续集成—如果每段代码不只有一个人熟悉,那么就不会有什么交流瓶颈了。把代码持续集成到一个主干可以避免重复和不匹配的代码。
  • 重构—在当时的情况下,写的代码是解决已知问题的。通常,团队巧妙地解决了他们的问题,然后持续重构和修改代码,确保代码库能以最为高效的方式不断满足业务最新的需要。

然而给定的 XP 很难,它需要连续的训练和一定的时间保证才能做得好,高管们要的是速度。技术总监们、副总裁们、首席执行官们说“我希望我的工程团队获得更好的敏捷工程实践效果,使我们变得更快。”

最初,我同意 James Shore 所说的,XP 的确很难,实际上它违反了敏捷帮助团队更快的理念。事实上,XP 有陡峭的学习曲线,而且很自然的是,这需要一定的学习时间,学习 XP 的团队肯定比什么都不学的团队更慢。

所以,如果“更快”不是敏捷工程实践真正的价值,那么什么才是它真正的价值呢?

我认为,敏捷工程实践真正的价值是,它们让公司以某种方式拥抱变化,事实上,这将成为一种竞争优势。

为什么呢?

当我们进入 2014 年,这个论点将在逻辑上成为合理的。如果现实果真如此,那么以此推理,在接下来的十年间,那些充分利用软件构建流程的公司将走向成功

是的,这个道理大家都懂,有很多竞争优势是软件之外的。例如,那些能够充分利用数学工式去预测未来股票的对冲基金将拥有竞争优势。那些能够充分利用布艺和颜色去预测未来时尚的零售商店将拥有竞争优势。但是,随着 7 乘 24 小时的网络连接和全球信息共享,你刚想到一个好点子,你的竞争对手就将会去模仿它了。

这让我们兜了一圈又回到刚才的观念,那些能够充分利用软件构建流程的公司将超过他们的竞争对手,拥有巨大的竞争优势。这个概念的关键词是“流程”。它是技术栈无关的。从敏捷工程实践中充分获益的关键是,出现危机的时候仍能极力地坚持最起码的流程原则。这就像是锻炼身体。假设你休假的时候每周锻炼五次,上班的时候每周锻炼一次,那么实际上你每周只会锻炼一次。如果离截止日期还远的时候才实践结对和 TDD,一旦要到截止日期了就把敏捷抛到一边,那就说明你并没有勤奋地实践敏捷流程。

能够让企业通过使用敏捷工程实践获益的五种具体方法是:

1.可以随机应变的灵活性

我的公司为大型零售商创建了一个电子商务平台。在六个月的开发周期中,前三个月团队具有自主权。我们两周一个迭代,并且每两周发布一次代码。某天,产品团队做竞争情报研究时发现,一个竞争对手针对退货修改了他们销售和信用卡的处理方式。因为我们完成的代码上个迭代已经充分测试了,并和其他代码集成好了,而且已经发到生产环境中了,所以我们清楚自己的代码非常可靠,即使变更也不会有任何宕机或缺陷之类的重大风险。

第二天,我们决定不再继续既定的构建,而是开了个需求收集会,估算多久能完成新的特性,并对用户故事重新排序。数天之内,我们就把一组新特性确定好范围,排好优先级,由团队优先来完成这些任务。两周之后,修改后的信用卡退货引擎就发布到生产环境中了。没发现任何缺陷,销售团队对此非常满意。

这完全得益于包括测试驱动开发在内的敏捷工程实践,公司清楚他们能够依靠技术团队快速应变,尽可能地降低在线品牌展示质量的风险,从而始终保持着市场的竞争力。

2.可以实时地重新分配开发团队的成员

如果要达到这种随机应变的灵活性,在两周内就发布新的信用卡退货引擎,那么团队在本迭代只为这个特性上安排两名工程师就不太够了,实际需要四名。由于团队采用了结对编程和集体代码所有权的缘故,所以团队中的成员熟悉每一段代码,我们可以随便拉一对已经完成其他故事的程序员去完成这个新的优先级更高的故事,当我们重新排定的优先级之后仍能维持原有的速率。

使用敏捷工程,项目不会因为某个摇滚巨星无法从其他事情中分身而阻碍了进程。整个团队可以转向新的需求。为新功能配备的最佳配置可以专心去完成新功能。团队处在一个不断交流的氛围中,所以为一个故事增加更多的工程师会很顺利,不会产生任何混乱。

3.自然而然地避免了去废弃持续了几个月的工作

经过充分测试再发布生产环境的代码还有另外一个好处,一旦完成就不会被废弃。当我们确认需要完成信用卡退货特性时,就可以把工作重心直接转到这个优先级更高的新特性上。在这个过程中不需要废弃任何工作。在我们要开始这项新工作之前,没有必须要完成或推迟的半成品。已完成的所有代码都是高质量的、无缺陷的、完整的和有效的。

4.坚信已完成的特性永远代表着项目最重要的那部分

几年前,我的团队为一个大型政府机关项目做一个项目。这个项目是个长期合作,我们编码就用了一年。因为我们使用了敏捷工程实践,所以代码会被持续发布到生产环境中。

在某一天的早晨,一位干系人对这个项目的优先级有了一些新的想法。他担心因此可能会使其他重要功能无法完成了。他不熟悉每天的项目进度,也没有意识到敏捷的商业价值。

所幸,工程团队实际上是紧贴业务开展工作的,每两周按业务的优先级完成他们的工作,在过去的一年中,最重要的特性已经完成了、已经完全集成在一起了、已经充分测试了,它们的质量坚若磐石。

公司坚信在任何时间点完成的都是最重要的特性。干系人可以放心软件的任何变更,不但多大都可能,而且都可以欣然接受且风险很低。

5. 能营销活动策划充满信心

我们都曾经经历过这样的事,公司策划一场营销活动。我经常和团队在一起工作,他们需要在确定的日期内完成软件的编码。去年,我负责一个教育服务性企业的项目。一场营销活动已经全面铺开。我们有一个明确的期限:返校日期。他们希望返校期间能产生巨大的销售额,所以这些特性必须在八月十号之前上线。由于日期是固定的,这场营销在电视、报刊和在线广告上也花费了大量的费用,电子商务网站必须在规定的日期内具备最必要的特性。

通常接下来会发生什么事呢?我看到无数的工程团队最终会处于一种左右为难的境地。八月一号那天,产品经理意识到无法满足时间要求,如果想让产品如期上线,工程团队就要在接下来的两周里每周拼命地干 100 小时的活。但是,如果团队的工作强度如此之大,就会把人搞得非常地疲劳和焦虑,这样就很容易出现工作上的失误。

如果团队能够设法做到严守敏捷原则,继续依靠工程最佳实践,那么测试驱动开发、持续集成、结对编程和其他方法将引导团队准时地发布并灵活地安排休息时间。

团队只需这么做。我们在高压时坚守敏捷原则,并握紧手里的枪。使用敏捷能为营销活动带来信心,其关键就是坚信这样的一个事实,其实许多特性可以有多种实现方式。例如,假设有一个特性是要把视频上传到你的网站上,那么至少有两种实现方式。方案 A:花 10 天时间开发,使用户可以上传任何语言、任何格式和任何长度的视频文件。方案 B:花 1 天时间开发,让用户可以把 YouTube 的链接粘到一个输入框里。

你怎么选择我不得而知,但如果我是产品经理,而且时间已经到八月一号了,那我肯定会选择方案 B。

最终的结果是,我们在八月十号成功地发布了产品,它包含了所有的关键特性。我们有意欠下了大量的技术债,包括选择用一天的时间完成视频上传的特性。八月十号一帆风顺,之后我们把新特性和之前欠下的技术债重新排定了优先级。我们把技术债和新特性一起放到故事列表中重新排序,快速恢复到了两周一个迭代的平稳工作效率中。

概括起来说,敏捷工程实践的价值已经超越了工程团队,对整个企业的好处是显而易见的。持续运用高效开发过程的公司将带着巨大的优势同我们一起走进下个十年。让你的团队以最适合的方式去实现敏捷工程实践吧,如果你有任何问题都可以向我提问,我会非常乐意地与你一起一边喝喝咖啡、喝喝啤酒一边详细地交流讨论的。

关于作者

Debbie Madden是一位经验丰富的管理人员、战略顾问和接口人。目前,她是 Stride 的首席执行官,为高管和企业家们提供战略建议和一些首席惊喜官的咨询。Debbie 信奉以人为本。她的生活和工作都坚守着热情、诚实、勇敢、公平的基本原则。她专门为技术、专业服务和初创公司提供指导和咨询。Debbie 坚信,在接下来的十年软件构建流程将成为公司的巨大优势。敏捷和初创引发了她的思考。她相信,迭代、协作的方法会把权力授予团队,个人爱好与商业优先级将保持一致。已经过去的十年,Debbie 一直在经营 Cyrus Innovation。最近,她已经成为 Cyrus 的首席执行官,把这家公司从一无所有发展到了规模达 60 人、价值数百万美元、五次获得 Inc5000 强增长最快的私营企业称号,并被 Crain 评为纽约最好的工作场所。

查看英文原文: 5 Ways Your Business Can Benefit from Agile Engineering Practices Today

2014-07-17 23:092240

评论

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

你知道,java项目中是如何获取文件地址的吗?

华为云开发者联盟

Java 路径 ClassLoader 文件地址 绝对地址

当 TiDB 遇上 Flink:TiDB 高效入湖“新玩法” | TiLaker 团队访谈

PingCAP

[Python公开课]零基础玩转Python基础篇----第七节:Python中的高级函数

是Dream呀

2月月更

如何找寻职业方向感

万事ONES

ONES

Flutter 屏幕采集实战分享

ZEGO即构

flutter 音视频开发 屏幕采集编码

基础架构部如何推动新一代云原生架构变革

星汉未来

开源 云原生 开源社区 云计算,

智能运维引擎 CudgX 更新 V0.2.0 版本,新增根据 MetricQPS 进行自动扩缩容!

星汉未来

云原生 算力 智能运维 扩缩容

CTF题目中遇到的PHP考点总结(一)

H

php CTF WEB安全

产品更新 | 数据物流引擎 DTExpress 新增算力市场及跨云传输

星汉未来

数据迁移 云算力 云 原生云 CTO

Python格式字符串的三种方法你都掌握了吗,%s%d%f+format()+f-string,深度测评YYDS实至名归

是Dream呀

2月月更

[Python公开课]零基础玩转Python进阶篇----第二节:Python的异常分析及解决

是Dream呀

2月月更

【思特奇杯·云上蓝桥-算法集训营】第2周----真题汇总+思路分享

是Dream呀

2月月更

Hive 数据倾斜问题定位排查及解决

编程江湖

一文看懂业界在离线混部技术

星汉未来

开源 云原生 服务治理 云计算, 混部

[Python公开课]零基础玩转Python基础篇----第六节:Python中的函数

是Dream呀

2月月更

开源算力引擎 BridgX 发布 0.6.0 版本:新增三种权限管理功能

星汉未来

开源 运维 云原生 云计算, 开源生态

YoloV5实战:手把手教物体检测

华为云开发者联盟

物体检测 模型 yolo YOLOv5 Labelme

使用s3fs在centos上挂载bucket

阿呆

S3

一行代码:开启 eBPF,代替 iptables,加速 Istio

Daocloud 道客

istio 开源项目 网络加速 服务网格 ebpf

Ti-Click:通过浏览器快速搭建 TiDB 在线实验室 | Ti-可立刻团队访谈

PingCAP

刚出炉的《Java开发手册黄山版》,我帮你们圈出了改动点!

捉虫大师

爬虫requests模块 入门到入狱 :基础知识+实战分析

是Dream呀

2月月更

跨平台应用开发进阶(二) :uni-app 实战

No Silver Bullet

uni-app 跨平台 规范 2月月更

详解CNN实现中文文本分类过程

华为云开发者联盟

机器学习 CNN 深度神经网络 文本分类 Word2Vec

金融行业研发管理平台选型

帅气IT小哥

9期视频告诉你如何更正确更高效的使用Git

阿里云云效

git 阿里云 云原生 代码 研发

【Python训练营】Python每日一练----第2天:门牌制作

是Dream呀

2月月更

博云信创云管平台入选工信部推荐解决方案名单,头部券商信创案例获应用示范单项!

BoCloud博云

云服务 信创 云平台

Serverless 与工具链建设

刘宇

Serverless 工具链

NodeJS搭建本地服务指南

编程江湖

node,js

[Python公开课]零基础玩转Python进阶篇----第一节:Python中的文件操作

是Dream呀

2月月更

从敏捷工程实践中获益的五种途径_文化 & 方法_Debbie Madden_InfoQ精选文章