写点什么

Netflix 试图通过开发者自治调和大规模 API

  • 2016-09-13
  • 本文字数:1557 字

    阅读完需:约 5 分钟

最近在 Netflix 公司的技术博客网站上,该公司的工程经理 Katharina Probst 和 Justin Becker 合作撰写了一篇博客,内容是关于如何在API 环境中维持开发者自治的问题。这篇发布于2016 年8 月23 日的博客帖子题目为“工程上的权衡及Netflix API 的重架构”,文中探究了在API 环境中使用多种团队共享的服务时,调和开发者代码和流程所有权中所存在的难点问题。

当前微服务正在崛起,完全自包含、自维护的软件栈也正受到软件工程社区的日益重视(例如使用 Docker 这样基于容器的开发很受欢迎),但是这种趋势与一些用户的需求是相互矛盾的,因为这些用户希望能访问一些不同类型服务的数据,但不希望大量额外地增加自身应用的复杂度。对于围绕着代码复用和协作的工业标准最佳实践而言,它们与微服务间也有着复杂的关联性,因为它们在外部软件的微服务中建立了内部依赖。

在这篇博客帖子中,Probst 和Becker 写道:“……我们的工作就是去调和貌似冲突的工程原则,其中包括了速度及完全所有权与代码复用最大化及合并之间的冲突”。鉴于API 本身就意味着多个服务间的通信,一个棘手的问题就是如何去维持一个团队内部所使用数据的所有权问题。如果每个微服务都具有与消费者直接通信的API,那么该微服务必须承担其所有消费者的各种请求,对请求整体的削弱就构成了一个完全独立且最大产出的服务。但是如果存在一个用做所有微服务缓存层的独立API,尽管这意味着个体服务对用户实际上如何消费自己的数据并没有多少的控制权,但是这也使得API 可以涵盖所有可能的消费者请求。

Probst 曾在 QCon 2016 纽约大会上报告称,为更好地适合很多自治应用的需求,Netflix 正计划对自身 API 进行可能的改进。在 Netflix 有一个 API 用于提供微服务与各自 API 间的编排服务。在由该 API 承担所有独立微服务中一千多种不同设备的消费者请求的同时,也引入了单点故障问题。即该 API 的宕机将会影响到所有的消费者服务,而不是仅仅影响到一小组相关用户。为缓解这样的服务污染的隐患,Probst 计划在未来版本的 API 中采用容器技术。她在 QCon 大会的报告中提出:“今后,当某个脚本对一大类情况都存在问题时……当某个设备或设备脚本不可用时,将不会影响到其它的设备,也不会影响到 API。”通过保留单一编排 API 并使用容器分隔过程实现对风险的降低,Probst 得以保留与所有面向消费者微服务通信的单一 API,进而形成完美的共享工具和服务的平台。而对很多微服务而言,共享工具和服务是一个臭名昭著的痛点。

虽然 Probst 已经确定了使用容器去分隔脚本等在内的一些关键 API 决策,但是很明显还存在其它的一些问题,这些问题尚未给出最优的解决方案。例如该博客帖子的一个主要话题就是,是否应该具有多个编排 API,这些 API 赋予底层服务对编排更大的控制能力;或是让已有的 API 包含更少的逻辑以成为更严格意义上的数据接口服务,而让大多数的逻辑围绕着消息而构建,并在将消息于逻辑自身服务组特定的逻辑层中提供给消费者之前,将该逻辑添加到数据层中。对于第一种方法,难点在于同时同步所有不同的编排,这构成了共享软件跨越多个服务分组的障碍。对于第二种方法,难点是对于非真实添加的功能,即仅是在各服务间做更大程度上的区分和更细粒度的控制,如何验证它们所导致的延迟增加。这个博客帖子最终并未给出明确的抉择,但是暗示了未来的选择取决于不同权衡间的妥协。考虑到随着通用工具、库和消费者连接性的需求增长会持续增加更多的独立自包含服务,所以可能当前并没有一种完美的解决方案。

查看英文原文: Netflix Attempts to Reconcile Large Scale APIs with Developer Autonomy


感谢夏雪对本文的审校。

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

2016-09-13 19:002099
用户头像

发布了 227 篇内容, 共 85.5 次阅读, 收获喜欢 28 次。

关注

评论

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

陕西西安等保测评单位有哪些?在哪里可以查到?

行云管家

西安 等保测评 等保测评机构

为什么 SQL 语句使用了索引,但却还是慢查询?

okokabcd

MySQL

元宇宙产业投资全景图,快人一步走进元宇宙新时代!

博文视点Broadview

各厂商的数据湖解决方案

五分钟学大数据

数据湖 6月月更

苹果称M2比intel i5强26倍 虚假营销的实情揭晓!

科技之家

【直播回顾】Hello HarmonyOS应用篇第六课——短视频应用开发

HarmonyOS开发者

HarmonyOS

IPO,联结一切的桥梁

鼎道智联

LP流动性挖矿系统开发生态系统详解

开发微hkkf5566

构建基于React18的电子表格程序

葡萄城技术团队

React 表格 纯前端表格技术

Springcloud Oauth2 HA篇

Damon

微服务架构 安全架构 6月月更

【高并发】彻底理解Nginx限流机制与实战

冰河

并发编程 多线程 高并发 异步编程 6月月更

web前端培训React如何原生实现防抖

@零度

前端开发 React

知名网络安全硬件平台厂商铵泰克加入龙蜥社区

OpenAnolis小助手

开源 网络安全 龙蜥社区 CLA 铵泰克

最佳实践 | 用腾讯云AI语音识别零基础实现小程序语音输入法

牵着蜗牛去散步

最佳实践 语音识别 小程序开发 腾讯云AI 语音输入法

喜报 | 旺链科技签约汨罗市文旅体产业项目,打造“链”上数字乡村

旺链科技

区块链 产业区块链 乡村振兴 汨罗市

Java 对象如何安全的 toString

HoneyMoose

GameFi新的启程,AQUANEE将于6.9日登陆Gate以及BitMart

西柚子

柴云鹏:创新能力的培养至关重要|OceanBase 数据库大赛访谈

OceanBase 数据库

oceanbase 数据库大赛

Ubuntu20.04设置静态IP

echeverra

Linux 静态IP

网络安全等级测评和商用密码应用安全性评估是一回事吗?

行云管家

网络安全 等级保护 商用密码

Java培训多线程+List分段解决批量更新太慢

@零度

List 多线程 JAVA开发

评“开发人员不喜欢低代码和无代码的8个理由”

代码制造者

程序员 编程语言 开发 iVX 低代码开发

《数字经济全景白皮书》银行财富管理篇 重磅发布

易观分析

理财 银行理财

技术干货 | Linkis实践:新引擎实现流程解析

康月牙

Apache 开源社区 WeDataSphere Linkis 使用实践

保姆级教程:如何成为Apache Linkis文档贡献者

康月牙

Apache GitHub 教程 文档 Linkis

Android 产生ANR后的Trace文件的解析

北洋

android 6月月更

kube-apiserver调度器核心实现

申屠鹏会

k8s

精益产品开发体系最佳实践及原则

阿里云云效

云计算 阿里云 精益开发 产品开发 开发

分布式数据对象:超级终端的"全局变量"

OpenHarmony开发者

OpenHarmony

细说腾讯如何做到直播延时降低90%以上方案

C++后台开发

WebRTC CDN 音视频开发 视频直播 直播低延迟

盘点现有开源软件许可合规工具

开源社

Netflix试图通过开发者自治调和大规模API_语言 & 开发_Margot Krouwer_InfoQ精选文章