50万奖金+官方证书,深圳国际金融科技大赛正式启动,点击报名 了解详情
写点什么

将持续交付与结对编程相结合:经验教训

  • 2025-10-14
    北京
  • 本文字数:1364 字

    阅读完需:约 4 分钟

大小:685.17K时长:03:53
将持续交付与结对编程相结合:经验教训

结对编程和持续集成可以相辅相成。Ola Hast 和 Asgaut Mjølne Söderbom 在他们在QCon London关于结对编程的持续交付的演讲中提到,每天多次推送到主干分支上在孤立工作时很难实现,这会导致延迟、大型 PR(Pull Request)和合并问题。结对编程使得即时代码审查成为可能,更容易重构,减少了缺陷,提高了团队的韧性。


在之前的文章中,Hast 和 Mjølne Söderbom 提到他们的团队使用结对和群体编程与TDD(测试驱动开发);没有单独的任务或单独的代码审查。这种方法提高了代码质量,减少了浪费,并促进了知识的共享。频繁的休息有助于保持专注和流畅。


结对编程和持续集成(CI)相互支持。真正的 CI 意味着每天多次推送到主干分支,或者在你完成一个小任务后尽快推送,Mjølne Söderbom 说。当开发者孤立工作时,这很难实现,因为每个变更都需要外部审查和协调:


如果我们的四人开发者团队孤立/单独工作,几乎不可能实现真正的 CI。他们将不得不一直打断彼此。这直接导致他们产生更大的任务和更大的拉取请求。这也打乱了我们自己的流程。然后整个 CI 的概念就崩溃了。我们经常看到其他团队发生这种情况。


Hast 说,如果人们孤立地工作,重构将变得特别困难,通常会被推迟,并承诺“以后”进行,而这永远不会发生。当人们孤立工作时,它增加了一层协调,以进行急需的重构,这要么导致合并地狱,要么更多地承诺以后进行。


在组织中,有太多的时间被浪费在等待上,尤其是在软件行业。这种浪费的时间很少得到组织的关注,因为它可能很难清晰地被看到,特别是对于管理层来说。他们的工作方式意味着通常作为开发流程一部分的许多流程是多余的,Mjølne Söderbom 解释道:


例如,由于我们将非常小的块部署到生产环境中,并且能够将功能隐藏在特性开关后面,因此不需要在其他环境中进行测试。


Mjølne Söderbom 提到,他们花很少的时间审查来自拉取请求的代码,因为他们在结对编程时持续进行所有审查。这不是我们特意去做的;这只是这种工作方式的自然结果,他说。


当一起工作时,你不仅减少了任务期间的浪费,还大大减少了我们所说的返工浪费;所有可能在任务“完成”后发生的事情,Mjølne Söderbom 提到:


由于我们使用 TDD、结对编程和 CI,我们留下了可以显著的可测量的高价值。


这导致生产环境中的错误更少,更重要的是,代码更容易更改,我们可以更快地开发未来的软件,他总结道。


InfoQ 采访了Ola HastAsgaut Mjølne Söderbom,内容涉及重构以及他们的工作方式给他们带来的好处。


InfoQ:你们是如何进行重构的?


Asgaut Mjølne Söderbom:进行必要的重构是非常困难的,因为它需要与每个人协调。人们倾向于说:“我们稍后会在另一个拉取请求中进行这个重构”。也就是说永远不会。


当以小步骤工作并迅速将代码投入生产时,我们可以轻松地进行一些整理/重构,将其部署到生产环境中,然后回到我们正在做的事情。这对于改进遗留代码是一个巨大的好处。


InfoQ:你们从团队合作的方式中得到了什么好处?


Ola Hast:当你长时间与一个小团队紧密合作时,你会非常了解他们。因此,心理安全感很高,压力水平很低,我们在一起工作时有很多乐趣。


团队中的共享知识给了我们韧性,这在我们都有小孩的情况下非常有帮助,就像生病或学校会议一样。有人缺席通常不会影响我们的进度,因为我们有连续性。


原文链接:

https://www.infoq.com/news/2025/10/continuous-delivery-pairing/

2025-10-14 14:004116

评论

发布
暂无评论

GreptimeDB 助力国家电网数字换流站打造稳定高效的时序数据底座

Greptime 格睿科技

时序数据库 国产化 智慧电网 国家电网

基于国产 Web 组态软件 TopStack 搭建隧道照明控制系统

图扑物联

物联网 组态软件 web组态 智慧隧道

大数据基础工程技术团队4篇论文入选ICLR,ICDE,WWW

阿里云大数据AI技术

大数据 阿里云

【深入浅出Spring原理及实战】「工作实战专题」叫你如何使用另类操作去实现Spring容器注入Bean对象 (1)

码界西柚

Java spring 框架 Bean处理

《自动机理论、语言和计算导论》阅读笔记:p428-p525

codists

编译原理

Xilinx ZYNQ的应用开发介绍

芯动大师

开发板 驱动 ZYNQ

苹果挖走大量谷歌人才,建立神秘人工智能实验室;李飞飞创业成立「空间智能」公司丨 RTE 开发者日报 Vol.197

声网

Partisia Blockchain 生态zk跨链DEX上线,加密资产将无缝转移

BlockChain先知

Partisia Blockchain 生态首个zk跨链DEX现已上线

石头财经

Partisia Blockchain 生态zk跨链DEX上线,加密资产将无缝转移

股市老人

DcmMWL-SDK

birdbro

andiod Java' DICOM

国内小白用什么方法充值使用ChatGPT4.0?

蓉蓉

openai GPT-4 ChatGPT4

【深入浅出Spring原理及实战】「开发实战系列」Spring-Cache扩展自定义(注解失效时间+主动刷新缓存)

码界西柚

spring Spring Cache 缓存控制 缓存能力

直播预告|第一批 Vision Pro 开发者开始弃坑了吗? 本周六一起听听三位 XR 开发者的真实想法!

声网

【深入浅出Spring原理及实战】「开发实战系列」重新回顾一下异常重试框架Spring Retry的功能指南和实战

码界西柚

spring Spring retry 重试机制 spring-retry

CCE云原生混部场景下的测试案例

华为云开发者联盟

云原生 华为云 华为云开发者联盟 华为云CCE

聚道云助力航空巨头,管理与信息化效率飙升!

聚道云软件连接器

案例分享

营销H5测试综述

京东零售技术

测试 企业号 5 月 PK 榜

AI 数据观 | TapData Cloud + MongoDB Atlas:大模型与 RAG 技术有机结合,落地实时工单处理智能化解决方案

tapdata

Tapdata Cloud 工单处理 大型语言模型LLM 检索增强技术RAG MongoDB Atlas

将持续交付与结对编程相结合:经验教训_后端_Ben Linders_InfoQ精选文章