Netflix开源用来服务1.25亿会员的云端闸道器Zuul 2
Netflix宣布开源其云端闸道器Zuul 2,Netflix称它为前门,所有流量请求必会经过该服务。Zuul 2作为Netflix最重要的基础建设之一,现在Netflix内部运行超过80个Zuul 2丛集,向后端百项服务每秒发送一百万次的请求,以服务1.25亿会员的需求。
Zuul 2中,过滤器的前端与后端都设置了Netty处理程序,用来负责处理网路协定、网页伺服器、连接管理以及代理工作。Netflix提到,Zuul的功能相当于在过滤器设置的逻辑。Netflix将Zuul 2不只使用在所有外部流量进入Netflix云端服务的入口,而同时也用于路由内部流量。
负责处理入站流量的过滤器用于验证、路由以及修饰请求。而端点过滤器用于回传静态回应以及代理后端服务的请求。而出站流量的过滤器则用于压缩、指标或是新增删除自订义标头等内容。
目前Zuul 2开源的核心功能包括HTTP/2与TLS伺服器协定。在灵活性功能方面,适应性重试功能(Adaptive Retries),是Netflix用来增加服务可用性以及灵活性的核心重试逻辑。后端服务并行保护功能,则可用来配置并行限制以避免后端服务过载。
另外,在运作的功能上,除了提供Request Passport以追蹤每一个请求的生命週期事件外,状态类别(Status Categories)可以列举请求的所有可能成功或失败的状态,而Request Attempts用于追蹤代理状态,这个功能对于除错重试以及路由特别有用。
还有一些功能这次未来得及开源,但将依计画不久后释出,其中包括Websocket/SSE,以及流量控管功能,防止来自恶意客户端的DDoS攻击,而Brownout filters则能禁用特定CPU资源密集的应用,以防止Zuul过载。最后,可配置路由提供使用者以档案设定路由规则。
有几项Zuul 2功能尚未开源,但是在Netflix内部服务是很重要的应用,供欲使用Zuul 2的企业参考。Netflix提到,合作伙伴最常使用的功能就是自助路由(Self Service Routing),他们为用户提供应用程式与API,根据请求的URL、路径、查询参数或是标头等资讯创建路由规则,并将这些规则发布到各Zuul实体中。
另一个重要的功能便是灵活的负载平衡,Netflix致力于使负载平衡智慧化,当数量庞大的节点中,出现故障或是缓慢的节点,他们的演算法会自动绕过这些问题,维持服务的可用性以及品质。
由于Netflix的弹性架构,允许任何人都可以启动容器丛集并置于Zuul之后,因此Netflix发现,他们需要一个自动检测并查明后端错误的服务。透过Mantis即时事件串流,他们建立了异常状态侦测,以汇总每项服务的错误率,并在服务出现问题时主动发出通知。
免责声明:本文为转载,非本网原创内容,不代表本网观点。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
最新文章
- DNF搬砖最佳宠物搭配指南
- DNF白金徽章变现攻略:如何巧妙出售白金徽章
- 寒潮蓝色预警:近两日最低气温 0℃线南压至江南南部至贵州南部和云南北部一带
- DNA 纳米机器人:可改造人造细胞,推动合成生物学发展
- 新型巨型里德伯原子成为精准量子温度计
- 《生化危机9》重大爆料:里昂确定回归主角,吉尔缺席引热议
- 广东:到 2027 年 绿色低碳循环经济体系基本建成
- 2024 财年美国对外军售额创历史新高:背后的战略与影响
- 离子阱量子计算在近年实现双码纠错
- 这次与肯德基的全新联动,星铁再次硬控玩家热情?
- 新年多城土地市场回温:杭州单价地王纪录 3 个月内两度被打破,民企恢复拿地
- 扎克·克雷格执导新版《生化危机》电影,发行权引多家大公司激烈争夺
- 广东:积极推进煤炭消费控制,全力构建以新能源为主体的新型电力系统
- 广东:到 2027 年,全力构建绿色低碳循环经济体系
- 长三角铁路春运再创佳绩:昨日发送旅客 310.2 万人次
- 海通策略:2025 年政策见效下市场望步入基本面驱动新阶段,结构上科技制造确定性更强
- 《最终幻想14》水晶世界青魔法师职业任务全攻略
- 上海:推出乡村振兴领域优秀博士后创新计划,打造高潜力创新人才‘储备库’
- 春节机票价格跳水至百元,航司退差价政策各异引关注
- 浙江:到 2030 年,LNG 年接收能力达 4250 万吨
- 上海:启动乡村振兴博士后创新计划,打造高潜力人才‘蓄水池’
- 币界网晚讯速递:SHIB币价攀升至0.00002044美元,日内涨幅达2.10%
- 不知火舞《街霸6》惊艳换衣秀,细节之处尽显匠心,玩家为之痴狂
- 中国汽车:奋力争夺超豪华市场入场券