写点什么

通过合并队列改善 GitHub 的部署

  • 2024-04-26
    北京
  • 本文字数:1029 字

    阅读完需:约 3 分钟

通过合并队列改善 GitHub 的部署

最近,Github 谈到了如何使用合并队列(merge queue)来实现代码更新。GitHub.com 的合并队列已经开发并扩展到了管理超过 30000 个拉取请求(pull request),以及相应的 450 万次 CI 执行。


合并队列系统将拉取请求组织成可部署的批次,通过 GitHub Actions 启动构建和测试,并通过遵循分支保护规定以防止更新中包含失败的提交,从而维护主分支的完整性。队列中相互冲突的拉取请求会被自动识别和排除,系统会根据需要重新分组。


GitHub 的员工产品主管 Will Smythe 和员工工程师 Lawrence Gripper 在一篇博客文章中详细阐述了 GitHub 使用合并队列的过程。除了提高开发人员的效率之外,采用合并队列的目的还在于提升开发人员在交付工作时的整体体验,防止有问题的拉取请求影响到规模更广的团队,并确保所有服务和仓库的流程一致并且高度自动化。


2021 年年中,GitHub 开始在几个较小的内部仓库中试用合并队列的功能。他们分阶段实现流程的变更,这涉及到大多数开发人员在每天清晨开始一天的主要工作之前的测试和修改恢复。随着时间的推移,到 2023 年,GitHub 系统性地将其大型 monorepo 和所有与生产服务相关联的仓库均迁移到了合并队列系统。


合并队列融入了 GitHub 现有的拉取请求工作流程,开发人员无需学习特定的 ChatOps 命令,也无需使用标签或特定注释语法进行状态管理,这增强了 GitHub 的开发人员体验。开发人员可以轻松地将他们的拉取请求排入队列,如果他们发现自己的更改有任何问题,只需单击一下即可退出队列。


在 GitHub 于 2023 年第三季度左右全面发布合并队列后,我们在 Hacker News 上看到了相关讨论。技术社区积极参与了讨论,一位用户重点介绍了他们几个月来 在 monorepo 拉取请求合并中使用该系统的情况,并对流程的实质性改进提出了肯定。他们还称赞了该系统的快速能力和基于 trunk 的可靠发布,并对该功能背后的团队表示了赞赏。


另一位用户询问合并队列是否会很快出现在 Azure DevOps 中,表示对其可用性很感兴趣。一位参与者在回复中指出 Azure Repos 缺乏更新,并指出其 SSH Git 继续依赖ssh-rsa主机密钥,而实际上 OpenSSH 已废弃该协议数年之久了。


每月,会有 500 多名工程师利用合并队列将 2500 个拉取请求集成到 GitHub 的大型 monorepo 中,这将部署变更的平均时间缩短了 33%。在 GitHub 定期进行的开发人员满意度调查中,一位工程师称赞合并队列是“在 GitHub 的变更部署方面,这是我最满意的生活质量提升之一!”


原文链接


https://www.infoq.com/news/2024/03/github-merge-queues/

2024-04-26 08:005395

评论

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

场景化面试:关于分布式锁的十问十答

面试官问

分布式锁

Fedora/REHL 安装 semanage

HoneyMoose

牛客java选择题每日打卡Day7

京与旧铺

7月月更

【LeetCode】装满石头的背包的最大数量Java题解

Albert

LeetCode 7月月更

详细页返回列表保留原来滚动条所在位置

小恺

7月月更

synchronized 和 ReentrantLock

zarmnosaj

7月月更

使用标签模板解决用户恶意输入的问题

猪痞恶霸

前端 js ES6 7月月更

微服务链路风险分析

阿泽🧸

7月月更 链路风险分析

看抖音直播Beyond演唱会有感

Empty

面试突击62:group by 有哪些注意事项?

王磊

Java MySQL 面试

如何组织一场实战攻防演练

穿过生命散发芬芳

攻防演练 7月月更

刷个算法,结果第一题就蚌埠住了~~

为自己带盐

算法 力扣 7月月更

小程序容器可以发挥的价值

Geek_99967b

小程序 小程序容器

猿桌派第三季开播在即,打开出海浪潮下的开发者新视野

融云 RongCloud

华为云ModelArts文本分类–外卖评论

逝缘~

深度学习 华为云 7月月更

解构运算符的理解与运用

是乃德也是Ned

7月月更

前端知识链条中少不了的一环--Ajax

是乃德也是Ned

ajax 前端 7月月更

Android 无限循环ViewPager滑动空白Bug及报错跳坑

芝麻粒儿

android 手机 7月月更

分布式算法入门之 Paxos 算法

宇宙之一粟

Basic paxos 7月月更

Java方向~~0基础小白如何快速脱离0offer的苦海!

KEY.L

7月月更

python 函数二三事

AIWeker

Python python小知识 7月月更

C++|TCP 服务端中接收文件

中国好公民st

c++ TCP通信 7月月更

图解网络:TCP三次握手背后的原理,为啥两次握手不可以?

wljslmz

TCP 三次握手 网络协议 网络技术 7月月更

devkit入门

乌龟哥哥

7月月更

在QWidget上实现窗口阻塞

小肉球

qt 7月月更

分布式不来点网关都说不过去

zxhtom

7月月更

MMAP

北洋

Andriod 7月月更

如何开发引入小程序插件

Geek_99967b

小程序插件

从 1.5 开始搭建一个微服务框架——调用链追踪 traceId

悟空聊架构

日志 链路追踪 traceId 悟空聊架构 7月月更

Promise

Jason199

Promise 7月月更

通过合并队列改善 GitHub 的部署_后端_Aditya Kulkarni_InfoQ精选文章