写点什么

Dave Farley:持续交付的基本原理

  • 2015-03-10
  • 本文字数:1913 字

    阅读完需:约 6 分钟

Dave Farley 伦敦QCon 2015 大会上提出,尽管在过去的时间里软件开发尚未达到最佳的水平,但当前的研究正表明持续交付的实行会带来重大的改进。Farley 说,持续交付给软件开发经济模式带来了改变,使大家可以更迅速地验证商业思路,并降低了缺陷率,当故障发生时也可以更加快速地恢复服务。

Farley 在讨论中展开讨论了“软件开发在过去的时间里尚未达到最佳的水平”,他引用了 KPMG 和 Logica 发布的一系列报告,以及麦肯锡的质量统计报告。在过去的20 多年里,软件行业一直在努力改进开发方法论,其中包括将顺序的方式(比如瀑布法)换成更加迭代化的过程(比如 Scrum ),但是 Farley 提出,我们却未能从根本性错误中汲取到教训。

软件交付的根本目的是为客户提供一个产品,为其验证商业思路,最后为最终用户提供价值。在客户和商业之间反馈是必不可少的,迭代过程一定要执行得快速、廉价、可靠。

Farley 提出,科学和科学的方法是人类最伟大的发明。在软件交付中,实现快速的反馈周期是这种科学方法的关键。Farley 说,科学方法的基本步骤包括描述问题、形成假设、推理论证和校验求证。

描述 - 基于经验和观察进行猜测。

假设 - 提出一种解释。

推导 - 对假设进行预测。

实验 - 对推导进行试验。

重复!

Farley 接着说精益思想的原则(比如“一体化质量”、“寻求整体最佳”和“增强了解”)能够大幅缩短软件交付的周期。Farley 举了一个传统软件开发方法的例子,它的交付周期有103 天,我们再来看看换成精益的持续交付方法,交付周期只有57 分钟。短的周期时间使商业理念得以快速地验证,从而改变了软件交付的经济模式。如果系统引入了缺陷,快速的周期可以缩短MTTR(修复前平均时间),因为较短的周期会更易于推断出要做哪些修改。

Farley 引用敏捷软件开发宣言的第一准则强调了持续交付的重要性,“我们的最高目标是,通过尽早和持续地交付有价值的软件来满足客户”,并用一连串陈述句完整地定义了持续交付的概念:

敏捷宣言的第一准则。

持续集成的逻辑延伸。

着眼全局看开发。

每次提交创造一个候选版本。

发到生产环境中才意味着结束!

Farley 说,持续交付的核心原则包括创建一个可重复的、可靠的软件发布流程,保持每件事都在版本控制之下,一体化质量,重新定义“完成”就表示已经发布了,使每个人都对发布流程负责,实行持续的改进。

这个核心原则应包含在部署流程的实现内,它的目的是使“开发人员提交了代码”就意味着这些修改是为客户价值的提供,是针对任何会给生产环境带来问题的变更的检测和预防。部署流程应支持各类组织间涉及到软件交付的工作协作,让每个人都能够看到系统内与流程相关的变更。

Farley 说,常常会有一系列反对组织内部实施持续交付的论点。第一个证据是,“持续交付只适合小型的项目,它不可能用于大型的项目”,看看谷歌的构建过程这个论点就不攻自破了。谷歌主要使用一个单独整体的代码库,针对每次提交运行持续构建和测试,这个库中有超过 1 亿行代码,每年有 6 千多万次的构建。

第二个论点是,“这风险太高了,发布始终是造成灾难的因素”,让我们看看亚马逊构建过程就可以回击这个论点。Farley 说 2006 到 2011 年间,在亚马逊上实现的持续交付将部署导致的运行中断降低了 75%,将部署导致的运行中断分钟数降低了 90%。

最后一个反对实施持续交付的论点是这么说的,“这种方式合适简单的网站,但我的技术太复杂了”。Farley 用惠普的故事进行了反驳,惠普转换了所有 HP LaserJet Firmware 产品开发方法,这是一个大型的、复杂的、基于硬件的项目,具有多个产品并历时 4 年。实施持续交付后开发人员生产力得到了 10 倍的增长。

Farley 最后的结论是实施持续交付会对商业产生积极的影响,并提出“持续交付改变软件交付的经济模式”。Farley 引用了企业管理协会(EMA)“DevOps 和持续交付”2014 年度报告大会的数据,有 87% 具有开发和运维职能的公司收入增长被评为“卓越的”,它们比 2013 年至少有 10% 的收入增长,与此相反,只有 13% 具有开发和运维职能的公司被评为只取得“普通的”或者是更糟的增长。

Farley 引用了 Puppet 实验室的“ DevOps 2014 年度状态报告”,说明持续交付促成更高的生产能力和更高的可靠性,故障发生时的 12 次服务都得到更加快速的恢复。Farley 再次引用 Puppet 实验室报告,说组织文化是 IT 性能和组织整体性能最重要的预测因子。

我们现在可以信心十足地断言,高的 IT 性能与强劲的经营业绩是分不开的,它有助于生产力、赢利能力和市场占有率的提升。

Dave Farley 演讲的幻灯片可以在伦敦 QCon 2015 大会网站日程页上找到,可点击“持续交付的基本原理(良好软件开发的文化与实践)”下载。

查看英文原文: Dave Farley on the Rationale for Continuous Delivery

2015-03-10 03:302298

评论

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

SAP 电商云启用 Enterprise Product Development Visualization Integration 的配置步骤

汪子熙

angular 电商 SAP commerce 5月月更

数据大屏,仅仅是数据展示吗?

葡萄城技术团队

数据分析 BI 数据可视化 数据大屏 BI分析

面试中被问到最多的 19 个 JavaScript 问题

海拥(haiyong.site)

JavaScript 5月月更

轻量迅捷时代,Vite 与Webpack 谁赢谁输

葡萄城技术团队

前端 vite webpack 轮子

Docker下的Spring Cloud三部曲之二:细说Spring Cloud开发

程序员欣宸

Java spring-cloud 5月月更

ChunJun支持异构数据源DDL转换与自动执行 丨DTMO 02期回顾(内含课程回放+课件)

袋鼠云数栈

大数据

超级全面的设计类网址导航

小炮

官宣|Apache Flink 1.15 发布公告

Apache Flink

大数据 flink 编程 流计算 实时计算

STM32+华为云IOT设计的动态密码锁

DS小龙哥

5月月更

python处理excel文件,python xlsxwriter 一文初掌握

梦想橡皮擦

5月月更

限时免费!六位袋鼠云数栈资深产品专家带来《数智赋能实战六讲》,欢迎报名

袋鼠云数栈

数据中台 大数据 开源

七、高可用之故障演练

穿过生命散发芬芳

故障演练 5月月更 高可用设计

IDC Panel:智能运维在金融行业中的场景化应用

BizSeer必示科技

火山引擎推出基于全新视角的 Web 端性能监控方案

字节跳动终端技术

字节跳动 Web 性能监控 火山引擎

五年谷歌ML Infra生涯,我学到最重要的3个教训

OneFlow

机器学习 深度学习 深度学习框架 MLOps Data Infra

Java并发机制的底层实现原理

急需上岸的小谢

5月月更

【高并发】ThreadLocal学会了这些,你也能和面试官扯皮了!

冰河

并发编程 多线程 协程 异步编程 精通高并发系列

【刷题第一天】蜡烛之间的盘子

白日梦

5月月更

导航网站合集 | 你想要的资源它都有

小炮

Java 基础语法

源字节1号

软件开发 前端开发 Java后端 小程序开发

《对线面试官》Java泛型

Java3y

Java 程序员 编程语言 java 5月月更

面试突击45:为什么要用读写锁?它有什么优点?

王磊

Java 面试

养殖场新来了个“AI管家”

华为云开发者联盟

hilens ModelArts Pro 养殖场 AI摄像头 天视通

OceanBase 源码解读(十):一号表及其服务寻址

OceanBase 数据库

oceanbase 源码解读

web前端培训项目的 Vite 迁移实践分析

@零度

前端开发 vite

一文带你了解 「图数据库」Nebula 的存储设计和思考

NebulaGraph

数据存储 图数据库

BI系统打包Docker镜像及容器化部署的具体实现

葡萄城技术团队

Docker 数据分析 BI BI 分析工具

安全领导力| GitLab 持续位列 Gartner AST 魔力象限

极狐GitLab

安全

[Day38]-[二叉树]-二叉树的右视图

方勇(gopher)

LeetCode 二叉树 数据结构算法

福昕软件:用PDF辅助技术弥合阅读障碍者的数字鸿沟

联营汇聚

千人千面工作台,轻松定制你的移动业务场景

BeeWorks

Dave Farley:持续交付的基本原理_DevOps & 平台工程_Daniel Bryant_InfoQ精选文章