getway和zuul在zuul没有进行参数调优的时候,getway的性能会远高于zuul。

spring gradlew配置网关spring gateway springcloud网关gateway和zuul_spring


分析,在空负载的时候,SpringCloud Gateway比zuul 1 性能高50%左右,在模拟处理50ms业务后,,SpringCloud Gateway比zuul 1 性能高9倍左右。

但是考虑到zuul使用默认配置,结果可能不准,上网查找zuul生产优化配置调优后再次进行50ms业务处理压测。而SpringCloud Gateway查阅资料后暂无需优化。

zuul优化参数参考如下:

spring gradlew配置网关spring gateway springcloud网关gateway和zuul_spring cloud_02

性能比较结论

在实际生产使用中zuul 1与gateway性能没有差距:
在实际生产使用中,zuul 1虽然使用的是同步io,但是可以通过参数优化提高性能理论上可以达到极限性能,而springcloud gateway使用的是异步io,不需优化既可以达到接近极限的性能。

zuul1与gateway选择参考
如果是新的spring cloud项目,还是使用getway ,spring的官方都在主推getway,然而 zuul目前只支持到1.3.1版本,后来zuul升级版zuul2,然而zuul2它也是使用异步的netty,getway更加兼容如springcloud;

SpringCloud Gateway 简介

springcloud getway 它是基于spring 5.0 、spring boot 2.0 和spring reacter,为微服务提供一个简单有效的网关API路由接口。

Spring Cloud GetWay 作为Spring Cloud生态系统的网关,目标是为了代替zuul,SpringCloud GetWay 是基于webFlux框架实现的,而WebFlux框架底层则使用了高性能的Reactor模式通信框架Netty。
spring cloud getway的目标,提供统一的路由方式,基于Filter链的方式提供了网关基本的功能,例如:安全,监控/指标,和限流。
Spring Cloud Gateway 底层使用了高性能的通信框架Netty。

Gateway 由三部分组成:
(1)Filter(过滤器):
使用它拦截和修改请求,并且对上游的响应,进行二次处理。

(2)Route(路由):
一个Route模块由一个 ID,一个目标 URI,一组断言和一组过滤器定义。如果断言为真,则路由匹配,目标URI会被访问。

(3)Predicate(断言):
这是一个 Java 8 的 Predicate,可以使用它来匹配来自 HTTP 请求的任何内容,例如 headers 或参数。断言的输入类型是一个 ServerWebExchange。

微服务网关Zuul和Gateway的区别

Zuul:
使用的是阻塞式的 API,不支持长连接,比如 websockets。

1、底层是servlet,Zuul处理的是http请求
2、没有提供异步支持,流控等均由hystrix支持。
3、依赖包spring-cloud-starter-netflix-zuul。

Gateway:
Spring Boot和Spring Webflux提供的Netty底层环境,不能和传统的Servlet容器一起使用,也不能打包成一个WAR包。

依赖spring-boot-starter-webflux和/ spring-cloud-starter-gateway

提供了异步支持,提供了抽象负载均衡,提供了抽象流控,并默认实现了RedisRateLimiter。
二、相同点:
1、底层都是servlet

2、两者均是web网关,处理的是http请求

三、不同点:

1、内部实现:


  gateway对比zuul多依赖了spring-webflux,在spring的支持下,功能更强大,内部实现了限流、负载均衡等,扩展性也更强,但同时也限制了仅适合于Spring Cloud套件。


  zuul则可以扩展至其他微服务框架中,其内部没有实现限流、负载均衡等。


2、是否支持异步:


  zuul仅支持同步。


  gateway支持异步。理论上gateway则更适合于提高系统吞吐量(但不一定能有更好的性能),最终性能还需要通过严密的压测来决定


3、框架设计的角度:


  gateway具有更好的扩展性,并且其已经发布了2.0.0的RELESE版本,稳定性也是非常好的。


4、性能:


  WebFlux 模块的名称是 spring-webflux,名称中的 Flux 来源于 Reactor 中的类 Flux。Spring webflux 有一个全新的非堵塞的函数式 Reactive Web 框架,可以用来构建异步的、非堵塞的、事件驱动的服务,在伸缩性方面表现非常好。使用非阻塞API。 Websockets得到支持,并且由于它与Spring紧密集成,所以将会是一个更好的 开发 体验。


  Zuul 1.x,是一个基于阻塞io的API Gateway。Zuul已经发布了Zuul 2.x,基于Netty,也是非阻塞的,支持长连接,但Spring Cloud暂时还没有整合计划。

Spring WebFlux是随Spring 5推出的响应式Web框架。

1、spring-webflux支持两种开发模式:

(1)类似于Spring WebMVC的基于注解(@Controller、@RequestMapping)的开发模式;
(2)Java 8 lambda风格的函数式开发模式。

2、WebFlux是基于响应式流的,可以用来建立异步、非阻塞、事件驱动的服务。默认采用Reactor作为响应式流的实现库,也提供对RxJava的支持