写点什么

真正的持续集成:分布式代码仓库和依赖

  • 2017-05-08
  • 本文字数:2204 字

    阅读完需:约 7 分钟

微服务架构为软件开发带来了极大的灵活性,并加快了交付速度,但同时也带来了依赖管理问题。传统的解决方案虽然能够解决依赖管理问题,但都太极端,顾此失彼。于是,Netflix 尝试着寻找自己的解决方案,期待着在整个组织层面做到真正的持续集成。本文内容来自 Netflix 技术博客,已获得翻译授权,查看英文原文 Towards true continuous integration:distributed repositories and dependencies

在过去的 8 年间,Netflix 基于 AWS 构建了一套健壮的微服务架构,我们因此学会了如何在 AWS 上构建可靠的高性能服务。我们的微服务架构解耦了工程团队,让他们可以自由地构建、测试和部署他们的服务。这种灵活性最大化了团队的交付速度。在 Netflix,交付速度和可靠性是设计解决方案时首要的考虑点。

基于我们的架构,微服务为它们的消费者提供了一个客户端软件包,用于处理所有的 IPC(进程间通信)逻辑。这同时为服务的提供者和消费者带来了很多好处。除了客户端,微服务的很大部分是基于我们的运行时平台而构建的,这个平台由内部的软件包和第三方开源的软件包组成。

尽管服务开发团队有很大的发布灵活性,但他们的交付速度却受到了依赖软件包的影响。一项新增的产品特性可能要求很多微服务都用上最新版本的共享软件包或客户端,而更新依赖版本可能会带来风险。

简而言之,依赖管理是一项艰巨的任务。

更新项目的依赖可能带来潜在的问题。

  • 具有阻断性的 API 变更。这是最典型的场景,一个编译错误导致整个构建失败。由依赖锁定( Dependency Locking )和动态版本选择器组成的语义版本控制( Semantic Versioning )可以帮助大部分团队避免发生这种错误。不过,锁定在一个主版本上会让整个公司的代码升级变得很困难,导致配置漂移(Configuration Drift),并且需要长期地维护旧软件包。
  • 具有传递性的依赖更新。因为 JVM 的类路径是扁平结构,所以在一个应用程序里,一个类只能存在一个版本。像 Gradle Maven 这类工具可以处理版本冲突,避免同一个软件包的多个版本被引入到项目当中。这也意味着,你的应用程序里有一些代码依赖了具有传递性特征的软件包,但你的代码并没有针对它们进行过测试。
  • 具有阻断性的功能变更。理想情况下,这个问题可以通过执行适当的测试来缓解。软件包的所有者可以通过运行使用者的测试案例来了解他们对软件包功能的预期。

我们发现,为了解决大规模的依赖管理问题,很多公司使用了两种方案:共享最小化(Share Little)和单体仓库( MonoRepo )。

  • 共享最小化(或者干脆不使用共享软件包)最近在微服务领域很流行,它的核心论调是说,微服务之间不应该共享代码,服务之间只能通过 HTTP API 进行耦合。更有甚者,有人说直接使用拷贝加黏贴的方式来代替共享软件包。这是一种非常极端的解耦手段。
  • 单体仓库的核心论调是说,组织的所有代码应该全部保存在一个单独的仓库里。任何一个代码变更在提交到 HEAD 之前,都需要针对整个代码仓库进行编译和测试。内部软件包没有所谓的版本,只有 HEAD 代码。所有的提交在到达 HEAD 之前需要跨过一些门槛。第三方软件包需要通过“审批”才能被使用,而且仅限于一两个版本。

这两种方式都能解决大规模的依赖管理问题,不过它们也带来了一些挑战。共享最小化促进了解耦,也加快了工程速度,但牺牲了代码的重用性和一致性。单体仓库保证了代码一致性,并降低了风险,但牺牲了灵活性。不管采用哪一种方式,我们都需要对 Netflix 的开发基础设施和运行时架构做出重大的调整。况且,这两种方案会破坏我们所推崇的自由和责任文化

我们给自己提出了一个很大的挑战目标:

我们能否为 Netflix 的工程师们提供一种解决方案,它不但具有单体仓库的优势,还能保持分布式仓库的灵活性?

我们以单体仓库为蓝本,另辟蹊径,希望找出能够达到相同目的的可替代方案。单体仓库所要解决的核心问题是什么?我们能否在传统的二元集成世界里开发出一种新的方案?

我们的解决方案,虽然还在试验阶段,不过可以从中归纳出三个关键的特性。

  • 向发布者反馈。直接或间接地向共享代码所有者快速地反馈使用者所遇到的问题。同时,允许团队因下游依赖的中断而暂停发布。目前,我们不会把这类问题的责任归咎到使用者身上。通过向软件包所有者反馈他们的问题给 Netflix 带来的影响,希望他们能够负起应有的责任。
  • 来源管理。当有新版本发布时,为使用者提供一种安全的方式,用于自动增加软件包的版本。既然我们已经针对所有的下游依赖测试过每一个软件包,那为什么不直接让使用者知道新版本,从而加快新版本的采用速度呢!
  • 分布式重构。为共享代码的所有者提供一种方式,让他们可以全局地对 API 的使用者进行快速的重构。我们已经开始向使用了某些特定 Java API 的 Git 代码仓库发起了全面的拉取请求。我们已经做了一些试验,并希望在这方面有更多的投入。

我们的旅程才刚刚开始。我们的发布者反馈服务目前正处于 alpha 测试阶段,我们计划后续会大规模采用这个服务,紧接着会进行来源管理。我们的分布式重构试验让我们了解到进行快速的全局重构是多么的重要。我们也看到了通过我们所构建的工具来降低依赖图复杂度的可能性。我们相信,通过扩展和培养这种能力,我们的 Netflix 团队将会在组织层面做到真正的持续集成,并减少(甚至免去)依赖管理的痛苦。


感谢郭蕾对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ @丁晓昀),微信(微信号: InfoQChina )关注我们。

2017-05-08 19:002478

评论

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

SD-WAN实现SaaS应用加速和高效互联

Ogcloud

SD-WAN SD-WAN组网 SD-WAN服务商 SDWAN SaaS应用加速

大模型助力国际术语专业化,前后联动实现所见即所得

京东科技开发者

大模型技术及趋势总结

京东科技开发者

win版IDimager Photo Supreme 2024(图片管理软件)激活版

iMac小白

智源和港中文联合提出首个多功能3D医学多模态大模型(文本、定位和分割任务)

智源研究院

技术解读数据库如何实现“多租户”?

快乐非自愿限量之名

MySQL 数据库 多租户

AI大模型“行业数据集-场景应用创新计划”启动征集

智源研究院

低代码开发:加速工业数智化转型发展

EquatorCoco

低代码 工业 数智化

Rust这5个自动验证工具,你知道几个?

伤感汤姆布利柏

Lombok注解引发的空指针问题分析

京东科技开发者

华为云618营销季来袭,数据灾备方案为云端业务筑牢安全防线

YG科技

win版Radiant Photo(照片编辑美化软件) v1.3.1.458 (x64)特别版

iMac小白

win版 CCleaner(系统优化工具)v6.23绿色便携版

iMac小白

win版StreamFab Downloader(视频下载工具) v6.1.8.4 激活版

iMac小白

win版Driver Talent Pro (驱动人生) v8.1.11.46 特别版

iMac小白

液冷赋能,AI算力锐不可当

GPU算力

通义灵码上线 Visual Studio 插件市场啦!

阿里巴巴云原生

阿里云 云原生 通义灵码

通义灵码上线 Visual Studio 插件市场啦!

阿里云云效

阿里云 云原生 通义灵码

开发做一个欧洲杯直播比分预测平台,只需三步

软件开发-梦幻运营部

理解 HTTP 请求参数和响应参数的差异

Liam

Web HTTP API 请求参数 返回响应

凯捷咨询携手华为云发布数字化零售解决方案,共创数智零售新生态

Geek_2d6073

win版Topaz Gigapixel AI(人工智能图片放大工具) v7.2.2 (x64) 特别版

iMac小白

win版iTop Data Recovery Pro(iTop 数据恢复) v4.4.0.687 专业激活版

iMac小白

win版CorelDRAW Graphics Suite 2024(cdr2024) v25.1.0.269 激活版

iMac小白

低代码开发:引领HR数字化变革新时代

不在线第一只蜗牛

低代码 数字化 HR

win版4K Video Downloader Plus(4K视频下载器)特别版

iMac小白

Spring高手之路20——深入理解@EnableAspectJAutoProxy的力量

砖业洋__

Java spring 后端

独家|GenAI年中回顾,2024网络内容审核的API实战指南

爱AI的猫猫头

人工智能 网络安全 AIGC GenAI UGC

win版Firetrust MailWasher Pro (垃圾邮件过滤软件) v7.12.216 激活版

iMac小白

Aquila-Med LLM:开创性的全流程开源医疗语言模型

智源研究院

真正的持续集成:分布式代码仓库和依赖_DevOps & 平台工程_Netflix_InfoQ精选文章