写点什么

Shopify 是如何迁移到模块化单体架构的?

  • 2019-08-09
  • 本文字数:1323 字

    阅读完需:约 4 分钟

Shopify 是如何迁移到模块化单体架构的?

Shopify 高级工程师 Kirsten Westeinde 在 Shopify Unite 2019 大会上讨论了Shopify向模块化单体架构的演变。这包括使用设计收益线(design payoff line)来决定何时进行此更改,如何实现更改,以及为什么将微服务排除在目标架构之外。


一个关键的结论是,单体不一定是一个糟糕的架构,它具有许多优点,比如单个测试和部署管道。在项目开始时,当必须快速交付新特性时,这一点特别有用。只有在跨越了“设计收益线”时,也就是糟糕的设计阻碍特性开发的那一点,才应该开始改进架构。就 Shopify 而言,改进其架构并不意味着转向微服务,而是转向模块化单体架构。这结合了单体(例如单个测试和部署管道)和微服务(例如代码模块化和解耦)的优点。


Westeinde 认为,单体架构是一个很好的项目起点,他说:“其实,我建议新产品和新公司开始时使用单体架构。”她列举了其中的一些优点:


  • 一个项目包含所有代码;

  • 只有一个代码库,测试和部署都很简单;

  • 所有数据都可用,无需跨服务传递;

  • 一组基础设施。


由于这些优点,Shopify 一开始只是一个小型的 Ruby on Rails 单体,随着时间的推移,逐渐发展成为一个非常大的代码库。当这种情况发生时,它意味着 Shopify 开始变得不可维护,并且因此很难交付新特性。例如,更改一段代码会对看似无关的代码造成意想不到的副作用,并且构建和测试应用程序花费的时间太长。


Westeinde 援引 Martin Fowler 的设计耐力假说(design stamina hypothesis)解释说,是时候重构他们的架构了——一旦功能开发被糟糕的设计所阻碍,设计收益线就会被跨越,这意味着投入资源来修复它是有意义的。


最初,Shopify 将微服务视为一种可选的、更易于维护的架构。然而,由于分布式系统的复杂性,它被排除在外,取而代之的是更易于维护的单体架构:


我们意识到,我们喜欢单体所有的东西,代码都在一个地方,而且向一个地方部署。我们遇到的所有问题都是由代码中不同功能之间缺乏界限所直接导致的。


Westeinde 解释说,他们意识到他们的设计目标是提升系统的模块化,比如使用微服务,同时保持一个单一的可部署单元,像一个单体。为了实现这一点,Shopify 采用了模块化的单体模式。这使得代码之间有了边界,但要使代码都在同一个位置并且部署到同一个位置。迁移路径如下:


  • 代码重组:最初,代码的组织方式类似于典型的 Rails 应用程序,顶层部件以技术组件命名,如控制器。这被更改为基于业务功能进行组织,如“账单”和“订单”,从而更容易定位代码。

  • 隔离依赖关系:每个业务组件彼此隔离,然后通过公共 API 供外部使用。他们内部开发了一个名为 Wedge 的工具,它跟踪每个组件的隔离情况。它构建一个调用图,然后计算出哪些调用(比如跨组件的调用)违反了规则。

  • 强制边界:一旦每个组件都实现了 100%的隔离,它们之间就有了强制的边界。其思想是,当代码试图访问它没有显式依赖的组件的代码时,就会出现运行时错误。以这种方式声明依赖关系也将使它们在依赖关系图中可视化。


最后,Westeinde 解释说,这个例子很好地说明了架构如何根据业务需求发展:


良好的软件架构是一项不断演化的任务,而应用程序的恰当解决方案完全取决于你的操作规模。


完整的演讲可以在网上观看,也有相应的博客文章


原文链接:


How Shopify Migrated to a Modular Monolith


2019-08-09 08:002721
用户头像

发布了 888 篇内容, 共 626.7 次阅读, 收获喜欢 1619 次。

关注

评论

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

小智常见报表示例--层次坐标--组内占比报表

小智数据

自定义报表控件 小智开源报表 小智BI 报表打印 组内占比报表

从基础到高级应用,详解用Python实现容器化和微服务架构

华为云开发者联盟

Python Docker 微服务 华为云开发者联盟 企业号2024年7月PK榜

观测云:数据驱动决策的智能分析平台

可观测技术

拼多多商品详情数据接口全解析:获取商品信息的高效途径

tbapi

拼多多 拼多多API接口 拼多多商品详情数据接口

详解 Apifox:批量添加接口请求 Body 参数的方法

Apifox

程序员 前端 后端 API body

Meme“吞噬”市场,VC项目失宠,加密市场下一步何去何从?

区块链软件开发推广运营

dapp开发 区块链开发 链游开发 NFT开发 公链开发

AI 应用实战营 - 作业 五 - SD WebUI

德拉古蒂洛维奇

MQTT & micro-ROS:构建高效的机器人应用

EMQ映云科技

物联网 机器人 mqtt emqx

碳课堂|什么是碳标签?产品为什么要贴上“碳标签”?

AMT企源

数字化转型 双碳 碳管理 碳标签

【论文速读】| TCSR-SQL:面向表内容感知的自检索文本到SQL方法

云起无垠

小智常见报表示例--层次坐标--跨层累计报表

小智数据

小智报表 小智开源报表 跨层累计报表 小智常见报表示例

Aloudata 入选 Gartner 中国代表性数据基础设施供应商列表

Aloudata

数据 Gartner 数据管理 数据基础设施

蓝亚盒子迁移上云,华为云助力开启元宇宙直播电商新纪元

华为云开发者联盟

云原生 华为云 元宇宙 华为云开发者联盟

解决多源异构数据整合难题"良策“,助企业高效管理数据资产

Aloudata

数据管理 Data Fabric 多源异构

【YashanDB知识库】virt虚拟内存远大于res内存问题分析

YashanDB

yashandb 崖山数据库 崖山DB

小智常见报表示例--层次坐标--交叉表累计报表

小智数据

自定义报表打印控件 小智开源报表 交叉表累计报表 小智BI 小智报表常见示例

软件测试学习笔记丨Web浏览器控制

测试人

软件测试

小智常见报表示例--层次坐标--逐层平均值报表

小智数据

类excel报表 自定义报表控件 报表批量打印 小智开源报表

苏州企业如何通过IT外包实现降本增效?苏州IT外包案例分享

苏州服务器托管

IT外包公司 IT外包服务

安全与便捷并行,打造高效易用的用户支付体验

HarmonyOS SDK

HarmonyOS

苏宁商品详情数据接口(suning.item_get)丨苏宁API接口

tbapi

苏宁API 苏宁商品详情接口

小智常见报表示例--层次坐标--循环引用报表

小智数据

报表批量打印 自定义打印控件 小智开源报表

淘宝/天猫商品详情API接口与电商数据质量管理的结合应用

技术冰糖葫芦

API API 编排 API 文档 API 协议

快速明白高校采购云管平台4大必要性

行云管家

云计算 云服务 高校 云管平台

deepin 社区月报 | 2024年6月,deepin V23 RC2发布,还有多款应用更新!

nn-30

Linux 开源 操作系统 社区 deepin

小智常见报表示例--层次坐标--分组排名报表

小智数据

报表批量打印 自定义打印控件 报表打印 小智开源报表工具 分组排名报表

观测云:多云监控的高效解决方案

可观测技术

小智常见报表示例--层次坐标--条件汇总报表

小智数据

自定义报表打印控件 报表批量打印 小智开源报表工具

Shopify 是如何迁移到模块化单体架构的?_架构_Andrew Morgan_InfoQ精选文章