微服务网关性能对比(微服务网关配置)

网友投稿 300 2023-01-09


本篇文章给大家谈谈微服务网关性能对比,以及微服务网关配置对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。 今天给各位分享微服务网关性能对比的知识,其中也会对微服务网关配置进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!

本文目录一览:

Spring Cloud——微服务网关介绍

为了解决以上的问题,API网关应运而生,加入网关后应用架构变为下图所示。

当引入API网关后,在用户端与微服务之间建立了一道屏障,通过API网关对微服务提供了统一的访问入口,所有用户端的请求被API网关拦截,并在此基础上可以实现额外的功能:

OpenResty是一个强大的Web应用服务器,web开发人员可以使用Lua脚本语言调用Nginx支持的各种以C以及Lua模块。

在性能方面,OpenResty可以快速构造出足以胜任10K以上并发连接响应的超高性能Web应用系统。

在国内,360、阿里云、腾讯网、去哪儿、酷狗音乐、新浪等都是OpenResty的深度用户。

但OpenResty是一款独立的产品,与主流的注册中心,存在一定的兼容问题,需要架构师独立实现其服务注册、发现功能。

Zuul是Netflix开源的微服务网关,主要职责是对用户请求进行路由转发与过滤。早期Spring Cloud与Netflix合作,使用Zuul作为微服务架构网关首选产品。

Zuul是基于J2EE Servlet实现路由转发,网络通信采用同步方式。

zuul 是netflix开源的一个API Gateway 服务器,本质上是一个web servlet应用。

Zuul可以通过加载动态过滤机制,从而实现以下各项功能:

Zuul的核心是一系列的filters,其作用可以类比Servlet框架的Filter,或者AOP。工作原理如下图所示:

Zuul可以对Groovy过滤器进行动态的加载,编译,运行。

Zuul2.x设计更为先进,基于Netty 非阻塞和支持长连接, 但是 SpringCloud 目前没有整合。 Zuul2.x 的性能较 Zuul1.x 有较大的提升。

Zuul2.x引入了Netty和RxJava,正如之前的 ZuulFilter 分为了 Pre、Post、Route、Error,Zuul2的Filter分为三种类型:

Spring 自己开发的新一代API网关产品,基于NIO异步处理,摒弃了Zuul基于Servlet同步通信的设计。

Spring Cloud Gateway 作为 Spring Cloud 生态系统中的网关,目标是替代 Netflix Zuul,其不仅提供统一的路由方式,并且基于 Filter 链的方式提供了网关基本的功能,例如:安全,监控/指标,和限流。

关键特征:

在性能方面,根据官方提供的基准测试, Spring Cloud Gateway 的 RPS(每秒请求数)是Zuul 的 1.6 倍。

Spring Cloud Gateway十分优秀,Spring Cloud Alibaba也默认选用该组件作为网关产品。

客户端向 Spring Cloud Gateway 发出请求。如果 Gateway Handler Mapping 中找到与请求相匹配的路由,将其发送到 Gateway Web Handler。Handler 再通过指定的过滤器链来将请求发送到我们实际的服务执行业务逻辑,然后返回。 过滤器之间用虚线分开是因为过滤器可能会在发送代理请求之前(“pre”)或之后(“post”)执行业务逻辑。

Spring Cloud Gateway 的特征:

参考:
http://www.ityouknow.com/springcloud/2018/12/12/spring-cloud-gateway-start.html

http://www.likecs.com/show-50293.html

https://zhuanlan.zhihu.com/p/299608850?utm_source=wechat_session

https://juejin.cn/post/6844903965352525838

https://blog.csdn.net/weixin_38361347/article/details/114108368

http://www.zyiz.net/tech/detail-98256.html

微服务网关层

API网关是所有客户端的统一入口。路由服务可以被用于很多目的,例如日志、限流、认证,从而做到应用无感知。API网关对于任意一种处理请求有两种方式处理。一部分请求只要简单路由到相应的服务;还有一些请求需要拆分到多个服务。API Gateway是实现微服务重要的组件之一,常用的网关Zuul, Nginx, Spring Cloud, Linkerd,Envoy,UnderTow。

为了评估API网关各自的性能,我们使用Apache的ab作为压测工具。(另外还可以用Gatling做性能测试)

测试结果和心得如下:

记网关APISIX调研

公司现状,生产上的服务器服务仅仅是使用nginx反向代理,随着公司发展,项目不断新增,需要频繁的修改生产服务器配置;证书过期需要开发人员配置(运营人员不熟悉生产环境不会配置,开发人员需要回公司找运营人员获取生产权限才能配置),更新麻烦;不具备限流、黑白名单配置等功能。更重要的是每更新配置nginx配置生效,都需要· nginx -s reload 重新加载配置影响用户使用。
为了进一步保障生产环境的 安全性 ,决定引入网关API

API网关 并非一个新兴的概念,在十几年前就已经存在了,它的作用主要是作为流量的入口,统一处理和业务相关的请求,让API更佳安全、快速和准确的得到处理,它有以下传统功能:

APISIX 是一个云原声,高性能,可扩展的微服务API网关,基于OpenResty和etcd实现。它进行动态路由和插件热加载,特别适合微服务体系下的API管理。

APISIX 是基于云原声的 微服务API网关 ,可以处理传统的南北向流量,也可以处理服务间的东西向流量。
APISIX通过插件机制,提供动态负载均衡,身份验证,限流限速等功能,并支持你自己开发的插件。
虽说 APISIX 是新出的产品,但它却功能强大具有蓬勃活力与生机。对比现有流行的网关,他具有强大的优势。而且市区活跃,对于用户的疑惑能够得到很快的回复解答,产品问题也及时完善修复。具体的大家可自己市区了解,我这里就仅做简单介绍。

网关APISIX 实战 分享敬请关注( https://www.jianshu.com/p/4f52aaf44738 )。

关于微服务网关性能对比和微服务网关配置的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。 微服务网关性能对比的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于微服务网关配置、微服务网关性能对比的信息别忘了在本站进行查找喔。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:SpringBoot引入Thymeleaf的实现方法
下一篇:详解java中产生死锁的原因及如何避免
相关文章

 发表评论

暂时没有评论,来抢沙发吧~