这4个微服务网关你了解吗?

前言

在微服务中,由于以业务划分会有很多个子模块。在面对外部系统的API调用时如果每个请求都直接到达对应的子模块接口,那么这样的请求会有很多个,尤其在业务庞杂的大型电商或支付系统中,对外和对内会形成无数个调用链路错综复杂。有时还要面对例如:鉴权、安全保护、限流控制等。因此,有一个统一用来管理和控制外部访问的API接口就会显得常重要。所有的外部请求都首先到达这个API接口,再经由这个接口API经过路由转发到达具体的某个业务系统。从而达到代理请求、统一管理控制的目的,这个API接口就叫API网关。

一、网关简介

1.1 什么是网关?

网关的角色是作为一个API架构,用来保护、增强和控制对于API服务的访问。它是一个处于应用程序或服务(提供REST API接口服务)之前的系统,用来管理授权、访问控制和流量限制等。这样REST API接口服务就被网关保护起来,对所有的调用者透明。因此,隐藏在API网关后面的业务系统就可以专注于创建和管理服务,无需关心这些策略性的请求。

1.2 API网关的四大职能

  • 请求接入:作为所有API接口服务请求的接入点,管理所有的接入请求。
  • 业务聚合:作为所有后端业务服务的聚合点,所有的业务服务都可以在这里被调用。
  • 中介策略:实现安全、验证、路由、过滤、流控、缓存等策略,进行一些必要的中介处理。
  • 统一管理:提供配置管理工具,对所有API服务的调用生命周期和相应的中介策略进行统一管理。

1.3 API网关的关注点

API网关并不是一个典型的业务系统,而是一个为了让业务系统更专注于业务本身,给API服务提供更多附加能力的一个中间层。

主要考虑许下几个目标:

  • 开发维护简单,节约人力成本和维护成本。即应选择成熟的简单可维护的技术体系。
  • 高性能,节约设备成本,提高系统吞吐能力。需要对API网关的特点进行一些特定的涉及和权衡。
  • 保持大规模的inbound请求接入能力(长短链接),比如基于Netty实现。
  • 最大限度地复用outbound的HTTP连接能力,比如基于httpClietn4的异步实现。
  • 方便灵活地实现安全、验证、过滤、聚合、限流、监控等各种策略。

二、四大网关对比

2.1 四大主流网关介绍

目前流行的用得较多的几个网关:Zuul 2、SpringCLoud Gateway、Kong、OpenResty。他们都基于各自不同的语言实现,也都有着各自不同的优缺点。

四大网关对比
网关语言限流鉴权监控易用性可维护性成熟度
SpringCoud Gateway基于Java语言可以通过IP,用户,集群限流,提供了相应的接口进行扩展。普通鉴权OAuth 2.0GateWay Mettries  Filter简单易用Spring系列可扩展性强,易配置可维护性好Spring社区成熟,资源少
Zuul 2基于Java语言可以通过配置文件配置集群限流和但服务限流,也可通过Filter实现限流扩展。Filter中实现Filter中实现参考资料少可维护性差开源不久,资源少
OpenResty基于Nginx+Lua需要Lua开发需要Lua开发需要开发几单易用,但是需要Lua开发可维护性差,需要大量lua脚本成熟,资料多
Kong基于Nginx+Lua根据秒、分、时、天月、年,根据用户进行限流。可在源码的基础上进行开发。普通鉴权,Key Auth鉴权,HMAC,OAuth2.0k可上报datadog,记录请求数量、请求数据量、应答数据量、接收与发送的时间间隔、状态码数量、Kong内运行时间j简单易用,API转发通过管理员接口配置,开发需要Lua可维护性差,需要大量lua脚本库相对成熟,插件开源

总结

基于不同的业务场景,选择不同的API网关组件,应对不同的系统流量和并发数。不同的业务场景,在技术选型上也是及其重要的一环。例如:Kong的性能虽然非常不错,适合做流量网关,但是对于复杂的业务系统不建议用Kong,因为会给系统的性能带来缺陷。再如SpringCloud GateWay/Zuul2对于Java技术栈来说比较方便,但是对于lua开发语言不方便。

 


既然都看完了整篇文章,相信对你一定有所帮助。原创不易,远离伸手党。

点击下方【打赏】小编,或者关注公众号给予支持,你们的每一份鼓励都将是小编伟大的动力。


同名原创公众号:   程序大视界
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序大视界

原创不易,请给点支持和鼓励吧

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值