为什么 Netflix 从大单体演进到联合网关?
创始人
2025-07-10 17:30:34
0

Netflix 以其庞大的原创内容库而闻名。你是否曾想过支撑其运营的技术?

今天,我们将探讨 Netflix Studio API 架构的演进历程。下图展示了其 4 个阶段。

01 大单体

早期,Netflix Studio 采用的是单体架构。想象一下一个庞大的互联系统,所有组件都是一个统一代码库的一部分。

02 直接访问

随着 Netflix 的发展以及与更多的电影公司合作创作原创内容,这块巨石开始成为路障。那么,下一步该怎么办?Netflix 的工程师们将单体分割成微服务。这种转变提高效率和自主性。它将其架构变成了一个服务网。

03 网关聚合层

但直接访问的效果却远非理想。为了克服这一难题,他们引入了网关聚合层。他们构建了一个 API 网关,将所有服务绑定在一起为客户提供统一的前台。这种设置非常适用于跨多个服务的用例。

试想一下,Studio 服务需要 3 个 API(如电影、制作和人才)来渲染前端用户界面,网关聚合层使之成为可能。

04 联合网关

网关聚合层本应带来秩序,但随着团队的壮大,服务的增多和领域复杂性的增加,开发网关聚合层变得越来越困难。为了解决这个问题,Netflix 使用 GraphQL 并引入了联合网关(Federated Gateway)。

这一策略允许领域专家管理自己的 "图",同时为各种 Studio 应用程序提供统一、高效的访问点。

GraphQL 是 Federated Gateway 的核心。这种强大的查询语言使用户界面能在一次往返中准确获取所需内容。GraphQL 联合允许 Netflix 建立一个单一的 GraphQL 网关,从所有其他 API 获取数据。

从单体到联合网关的过程说明,系统架构应适应不断动态增长的业务需求。

我们也不应该单纯地去复制 Netflix 和 Google 等巨头的基础设施,因为这些需求我们可能永远也遇不到。无需过度优化我们不存在的问题。

最好的架构是适合我们业务需求的架构,而不是模仿科技巨头。

相关内容

热门资讯

PHP新手之PHP入门 PHP是一种易于学习和使用的服务器端脚本语言。只需要很少的编程知识你就能使用PHP建立一个真正交互的...
网络中立的未来 网络中立性是什... 《牛津词典》中对“网络中立”的解释是“电信运营商应秉持的一种原则,即不考虑来源地提供所有内容和应用的...
各种千兆交换机的数据接口类型详... 千兆交换机有很多值得学习的地方,这里我们主要介绍各种千兆交换机的数据接口类型,作为局域网的主要连接设...
什么是大数据安全 什么是大数据... 在《为什么需要大数据安全分析》一文中,我们已经阐述了一个重要观点,即:安全要素信息呈现出大数据的特征...
如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
P2P的自白|我不生产内容,我... 现在一提起P2P,人们就会联想到正在被有关部门“围剿”的互联网理财服务。×租宝事件使得劳...
Intel将Moblin社区控... 本周二,非营利机构Linux基金会宣布,他们将担负起Moblin社区的管理工作,而这之前,Mobli...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...