专访乔梁:“持续交付”本身并不是目标,而是手段。

简介: 在过去10年中,持续交付思想已经从最前沿的想法变为业界公认的智慧。每个追求卓越的科技公司都希望能够随时随地发布,而无须工程师在晚上或周末进行部署。能够快速、频繁且安全地发布软件,并实现小批量交付,意味着我们可以快速获得对我们的想法的反馈。

在过去10年中,持续交付思想已经从最前沿的想法变为业界公认的智慧。每个追求卓越的科技公司都希望能够随时随地发布,而无须工程师在晚上或周末进行部署。能够快速、频繁且安全地发布软件,并实现小批量交付,意味着我们可以快速获得对我们的想法的反馈。我们可以构建原型并使用真实用户对其进行测试,从而避免开发那些对用户没有任何价值的功能。反过来,这也意味着产品更好,客户更满意,员工更快乐。这些能力对需要这种工作方式的每个组织来说,都是非常关键的。

然而,获得这种能力并不是一件容易的事情。组织需要对软件系统架构进行不断演进,使其支持尽快且有效的测试,以及快速部署,同时,还需要培养快速试验的文化。文化因素对于成功实施持续交付和通过持续交付实现产品管理实践至关重要。

乔梁曾与中国的各类组织合作,帮助它们实施持续交付并实现其效益。《持续交付》作者Jez Humble曾说:“我想不出比乔梁更合适的人选,来写一本关于如何根据实际经验实现这些想法的书。希望《持续交付2.0》的每位读者都能在提高软件交付能力的不断尝试中取得圆满成功,并利用这种能力来构建更好的产品和服务,以及更快乐、更高效的团队”。

今天,作者对持续交付的理解和认识,相比8年前,在广度和深度方面都有了较大的提升。今天我们有幸采访了《持续交付2.0:业务引领的DevOps精要》作者乔梁,来看看他的所思所想。同时有什么话想对作者说?


乔梁老师

异步社区:经典图书《持续交付》已出版8年,这本书在中国出版,您功不可没,可以说说您与《持续交付》和《持续交付2.0》的缘分吗?

乔梁:说到我与“持续交付”的渊源,可以追溯到11年前我与Jez Humble一起工作的时候。Jez Humble是《持续交付》的作者之一。

当时我与他正在为最早的一款开源持续集成工具CruiseControl贡献代码,但我们发现,它无法满足企业级持续快速发布软件的管理诉求。因此我们就决定开发一款新的持续集成与持续发布管理工具——Cruise,现在已经更名为GoCD,http://github.com/gocd/gocd。

2010年,此产品已经迭代发布了多个版本,而Jez Humble也完成了《持续交付》的写作。该书中提及的原则与实践绝大部分都在我们自己的团队实施过。我在多次看过该书的初稿后,决定在第一时间将其引入中国。于是,该书英文版还没有出版,我就开始自己联系国内出版社引进它的简体中文版权。

在过去的8年中,我也一直从事与持续交付相关的咨询工作,而且涉及多种不同类型的软件企业。在此过程中,也积累了自己的心得与体会,并对该领域有了一定的新认识。因此,才有了《持续交付2.0》这本书。 


异步社区: 《持续交付2.0:业务引领的DevOps精要》为什么为您的图书取这个名字?这本书是《持续交付》的延续吗?这本书您最想推荐给谁看?

乔梁:之所以称其为《持续交付2.0》,主要是因为它既站在“巨人”的臂膀上,对《持续交付》一书中所述的原则与实践进行了更加详细的解释,也提出了新的模型,即“持续交付双环模型”,对原有的框架体系进行了补充。对于那些希望提升持续交付2.0能力的软件企业来说,本书会使其更容易了解它的全貌,并在能力提升的过程中少走弯路。

它的副标题用“业务引领的DevOps精要”,主要是想提醒广大读者,无论什么样的方法与实践,都应该为业务价值负责,而不能与业务相脱离。任何问题的起点都是业务问题,而非技术问题。我们最终要解决的是业务价值问题,而非技术方案或软件交付问题。

 

异步社区:持续交付2.0的指导思想、工作理念和核心原则是什么?2016年DevOps在软件行业火了以后,很多人都在重读经典。是否可以结合您自己的理解,谈谈《持续交付2.0》这本书的内容可能对行业带来的改变?

乔梁:对于DevOps,目前行业内对其有很多种不同的定义,但其基石仍旧是持续交付能力。本书有很大篇幅讨论如何获得这样的能力,这也正是DevOps的精要部分。持续交付2.0是以精益思想为指导,以“识别并消除一切浪费”为工作理念,并坚持四项基本的工作原则,即“坚持少做”“持续分解”“坚持反馈”“持续改善”。我想这本书不会重要到对行业带来巨大的改变,但是正如我刚才提到的,我希望它能够让更多的企业少走一些弯路,以更少的资源投入得到持续交付能力的快速提升。

 

异步社区:我们了解到您曾先后就职于国内外知名移动设备公司和大型互联网公司,也担任了腾讯、搜狐畅游等多家互联网公司的高级管理顾问,每段工作经历带给您的收获分别是什么?可以具体说说吗?

乔梁有一种声音说:“持续交付(换成‘敏捷’也成立)只适合于互联网软件企业,变化不快、质量要求高的传统软件企业并不需要。”这句好像是说,互联网软件质量要求不高一样。这通常是望文生义的结果,事情并不是这么简单,这一点很容易判断。事实上,“敏捷开发方法”“持续交付”这些原则、方法和实践都诞生于传统软件开发环境。

尽管不同公司的不同类型的软件产品在不同生命节点上,面临很多不同的挑战,但是持续交付的原则与很多实践都是适用的。当我在移动设备公司做手机操作系统的开发工作时,使用本书中讲述的多种实践方法,仍旧可以比传统开发方式更快交付高质量的软件需求。

当然,我们也不能忽略所在环境上下文的不同。例如,对直接面向消费者的互联网分发软件企业来说,由于其软件运行环境复杂,传统软件开发方法中通过全面测试保障软件质量的方式根本无法覆盖很多应用场景,只能通过强大的监控能力和软件配置的灵活性,在版本发布后在用户发现之前收集问题,并快速修复。

另外,不同公司有不同的文化、环境和发展背景。因此,很多所谓的“不适合”可能是希望将其作为一整套严密的方法体系在较大范围“齐步走”。如果是这种情况的话,持续交付的确是不适合“共同致富”的。

 

异步社区:您在书中曾说:“我认为思想对每个人对事物的认知和理解至关重要。但咨询经历告诉我,对事物的正确理解,并不能确保正确的思想和理念在现实中落地,也不能确保对企业有大的和直接的帮助。”可以具体的聊聊为什么这么说吗?

乔梁这个问题可以算是上一个问题的延续。虽然在多年以前,我认为对“持续交付”有非常深入的理解,但那时我只是对“持续交付”本身有深入的理解而已,并不是对“它在企业中的落地”有很深入的理解。由人组成的企业是一个巨大的复杂系统,在这种环境中,两点之间的距离并不是直线最近,因此无法通过简单且相同的模式让其在企业内部落地生根。如果无法生根,就意味着无法成为组织的DNA,那么就很容易消逝。

 

异步社区:在创作《持续交付2.0:业务引领的DevOps精要》过程中遇到的最大困难是什么?您是如何平衡工作、写作和家庭的?

乔梁最大的困难是如何更好地组织这本书的结构。因为它的内容涉及软件产品研发过程的很多方面,我自己希望在书中能够全面覆盖,但又怕过于分散。最后还是把其中关于“组织建设”的很多内容删掉了,只留下了组织文化中的重点部分(希望以后能够再将其补充完整。)在写作期间,也有大约5个月的“完全停滞期”,感觉无法动笔继续写下去,是家人和朋友的鼓励才让我完成了这本书的写作。我的夫人不但为我校稿,还提出了很多建议。

 

异步社区:现在,每当人们提起DevOps时,总会联想到微服务、Docker技术、Kubernetes服务编排、部署流水线等。团队应用“持续交付2.0”理念,在保障交付质量的前提下,既提高交付频率又减少人力投入吗?可以具体聊聊吗?

乔梁2018年5月,我与Jez Humble在北京再次相聚时还讨论过相关问题。我们一致认为,与8年前相比,持续交付的理念已经被更广泛地接受,而工具技术的发展也令持续交付实践的门槛低了一些。但是,从组织、人员、架构的角度来看,还有较长的路要走。值得庆幸的是,“持续交付”本身并不是目标,而是手段。如果我们可以使用其他低成本的手段达成相同的目标,那也是非常不错的。通过很多企业的实施过程,我们也不难发现,它是一个波浪式的过程,即“增加投入——享受收益——再增加投入——再享受收益”的过程。

 

异步社区:您作为国内最早的持续交付实践和推动者之一,遇到的最大阻力是什么?同时最想感谢哪些人?

乔梁我个人遇到的最大阻力吗?自己想学习的东西太多,总是感觉时间不够。这本书也让我重新认识了我自己。我自己也使用《持续交付2.0》中的工作原则,就是“坚持少做,持续分解,坚持反馈,持续改善”。我也是需要不断强化练习、不断提醒自己。我并不是一个我很聪明的人,我只想每天比昨天的我进步一点点就好了。不追求跨越,追求“复利”就好。

最想感谢的人,一是多年前在我面前打开大门,让我看到新的工作方式的那些朋友和同事;二是给我很多机会,让我参与到组织改进过程中的客户和朋友,让我有机会在不同类型的企业中,与聪明勤奋的人一起工作,收获不一样的经验,使我能够掌握更多“持续交付2.0的落地方式”。


异步社区:对您工作和生活帮助最大的三本书要推荐给大家的?

乔梁与15年前的我相比,我现在每年的读书量应该是当年的数倍。当然,有些书读了也很快忘记了。我的感觉是,在人一生中的不同阶段,需要的书也是不同的。在我需要花大量时间写代码的那个年代,《解析极限编程》《重构》《代码整洁之道》对我的影响比较大。现在的工程师应该都能熟练掌握这些了吧。听说《重构(第2版)》(中文版)也要马上出版了,我也期待一下。

《重构2 》计划2019年3月出版《重构2 》计划2019年3月出版

        

乔梁老师著作

《持续交付2.0:业务引领的DevOps精要》

作者:乔梁

扫描二维码,一键当当购买

扫描二维码,一键京东购买

持续交付2.0不只是关于软件的交付模型,而是从业务问题出发,关注业务假设验证速度的双环业务模型。只有从业务目标出发的持续交付实践才有强大的创造力和生命力! 

书中指出,持续交付2.0双环模型高速运转的三个支柱分别是组织机制、软件架构和软件交付基础设施,同时给出了提升价值探索环以及快速验证环运转速度的多种可行方法。 

本书还为我们呈现了在企业内部改善持续交付2.0能力所需遵循的基本原则,包括组织文化建设、软件系统架构、业务协作、配置管理、构建集成、自动化测试、发布与监控七大板块,并指出各领域实践关键点,以及多种可实操性方法。同时,通过3个完整的实践案例过程分析,说明每个企业或团队都必须从自己的业务目标出发,根据自己的实际情况,制定自己的改善路线。

相关文章
|
3月前
|
存储 安全 Cloud Native
揭秘Quarkus安全秘籍:守护云原生应用,抵御未知威胁,助力企业稳健前行
随着云原生技术的发展,企业愈发倾向于在容器化环境中部署应用。作为一款专为云原优化的Java框架,Quarkus的安全性备受关注。本文介绍了Quarkus中的安全最佳实践,包括使用OpenID Connect进行身份认证、使用JWT进行权限控制以及保护敏感端点。通过这些实践,可有效提升应用安全性。同时,还需定期更新依赖库、使用HTTPS协议、加密存储敏感数据及定期进行安全审计,以确保应用的安全性和可靠性。
44 4
|
4月前
|
敏捷开发 测试技术 持续交付
软件测试中的自动化策略与实践云计算时代的网络安全挑战与对策
【8月更文挑战第30天】在软件开发的海洋中,自动化测试是一艘能够带领团队高效航行的帆船。本文将探讨如何搭建这艘帆船,从选择适合的自动化测试框架开始,到编写有效的测试脚本,再到持续集成的实施和测试结果的分析,我们将一步步揭开自动化测试的神秘面纱。你将学习到如何通过自动化测试来提升软件质量和开发效率,以及如何克服实施过程中的挑战。让我们一起启航,探索自动化测试的世界。
|
4月前
|
监控
揭秘:为何多年经验的网工还对光模块的光衰正常范围一知半解?这个秘密可能彻底改变你的网络优化策略!
【8月更文挑战第19天】在信息化时代,光纤通信至关重要,光模块作为其核心组件,其性能直接影响数据传输质量。光衰,即光信号在光纤中传输时的功率损失,是评估光模块性能的关键指标。本文将阐述光衰的基本概念、测量方法及对网络性能的影响,并提供光衰正常范围的标准,帮助网络工程师更好地理解与应用这一重要知识点,确保网络稳定可靠。
514 0
|
4月前
|
机器学习/深度学习 人工智能 监控
🎯目标精准打击:AI助力职场项目管理,确保每个细节都完美执行!
【8月更文挑战第1天】在快节奏职场中,项目管理至关重要。AI技术快速发展,正深度融入项目管理,以其卓越的数据处理和智能分析能力,助力团队精准设定目标并完美执行细节。通过分析历史数据和市场趋势,AI支持数据驱动的决策,预测风险和资源需求,确保目标既挑战又可行。在执行阶段,AI实时监控项目进展,及时预警并提供建议,自动化处理重复任务,使团队更专注于解决问题。AI的引入正引领项目管理走向更高效率、精确度和智能化的新时代。
78 0
|
5月前
|
监控 算法 数据挖掘
可持续发展的背景下,系统工程可以帮助我们构建、分析和实施那些旨在平衡经济、社会和环境目标的系统。
可持续发展的背景下,系统工程可以帮助我们构建、分析和实施那些旨在平衡经济、社会和环境目标的系统。
|
算法 Java 业务中间件
研发人员如何才能在做业务的过程中自我增值?
如何才能在做业务的过程中不再是资源一样被消耗而是像资产一样自我增值?如何成长?如何高效率地成长?如何让自己的成长走在环境要求的前面? 基于以上这些问题,本文将依次阐述以下内容: 先从“人的本质”入手(第二章节),接着探讨“人的成长”的本质(第三章节),最后再探讨业务和技术的一般规律及应对策略(第四、第五章节)。 需要注意的是,以下内容受限于个人能力和经验有限,在描述规律的过程中,可能会存在维度的缺失;或者当前描述的规律所涉及的维度并不是某些读者认知中的重点,因为事物不同的维度在不同角色和级别的人的认知中重要程度不同。
262 1
研发人员如何才能在做业务的过程中自我增值?
|
机器学习/深度学习 人工智能 自然语言处理
优先应用共识韧性交付带动,流程自动化成趋势,RPA前景可期
从Gartner报告看RPA市场前景,优先应用成共识,战略趋势不可少 优先应用共识韧性交付带动,流程自动化成为转型趋势,RPA前景可期
209 0
优先应用共识韧性交付带动,流程自动化成趋势,RPA前景可期
|
机器学习/深度学习 vr&ar
通过探索颠覆性技术的实验交付业务结果
企业需要为其创新实践取得理想的结果,首先要确定商业驱动的机会,以快速、廉价、让客户满意的方式探索颠覆性技术。并将重点放在工作范围,创新实践的位置以及与业务合作伙伴互动的过程上。
123 0
阿里云RPA成功实施落地的关键因素详解(下)
2019年RPA市场迎来大爆发,以uipath为代表的公司估值30亿美金,国内市场以阿里云为代表深耕了RPA多年,本文章分为由浅入深上中下三部分以阿里云RPA为例,全面讲解如何成功实施RPA自动化解决方案。
|
人工智能 算法 大数据
以赋能业务为目标的技术创新该如何做?
在软件研发从业者的视角里,创新分为两种:一种是与软件研发技术相关的创新,特别是在大数据和AI这种快速发展的领域,需要保持与技术进步的同频;而另一种创新,是与公司业务相关的,不断运用技术实现自动化、智能化、规范化,提高业务服务能力与用户体验。