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:001

评论

发布
暂无评论

openGauss的SQL引擎在3.1.0版本中做了哪些优化?

daydayup

openGauss内核荣获中国首个国际CC EAL4+级别认证

daydayup

从价值的角度看,为何 POSE 通证值得长期看好

股市老人

10分钟入门Flink--架构和原理

程序员半支烟

flink

openGauss赋能企业核心场景应用 | 华为全联接大会2022专题回顾

daydayup

openGauss内核分析(二.一):简单查询的执行

daydayup

金奖方案 | 一专多能、傲视寰宇,南大通用GBase8c数据库牛在哪里 #openGauss

daydayup

openGauss数据库从3.0.0升级到3.1.0操作实践

daydayup

鸿蒙生态星河璀璨 | 老程序员让HarmonyOS创新从“心”开始

最新动态

数据库迁移系列】从MySQL到openGauss的数据库对象迁移实践

daydayup

HarmonyOS NEXT,生命之树初长成

脑极体

鸿蒙 AI 应用

CTO如何帮助业务成功

程序员半支烟

HDC2023|余承东:元服务将卡片式体验带给消费者,加速鸿蒙生态的繁荣

最新动态

JDK中「SPI」原理分析

Java 架构 jdk spi

openGauss内核分析(二.二):简单查询的执行

daydayup

Zebec Payroll :计划推出 WageLink On-Demand Pay,进军薪酬发放领域

股市老人

Go 介绍

小万哥

Go golang 编程语言 跨平台 后端开发

从价值的角度看,为何 POSE 通证值得长期看好

西柚子

程序员是否适合创业

程序员半支烟

创业 程序员

只凭阿里大牛珍藏的并发编程笔记,我拿下了30K offer!

小小怪下士

Java 编程 程序员 并发编程 高并发

Zebec Payroll :计划推出 WageLink On-Demand Pay,进军薪酬发放领域

BlockChain先知

文心一言 VS 讯飞星火 VS chatgpt (71)-- 算法导论7.1 1题

福大大架构师每日一题

福大大架构师每日一题

ChatGenTitle:使用百万arXiv论文信息在LLaMA模型上进行微调的论文题目生成模型

汀丶人工智能

人工智能 自然语言处理 LLM模型

Zebec Payroll :计划推出 WageLink On-Demand Pay,进军薪酬发放领域

西柚子

多家合作伙伴与华为终端云服务签约 全面合作共建鸿蒙服务分发新生态

最新动态

华为阅读看好“短故事”新赛道 签约知乎盐言故事开启轻阅读

最新动态

C++实现对回收站里的文件进行操作

芯动大师

openGauss —— 智能优化器之基数估计

daydayup

服务端apk打包教程

越长大越悲伤

Java 服务端打apk包

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