img
Netflix给出了一个比力模糊的数据,大致Zuul2的性能比Zuul1好20%左右,这里的性能重要指每节点每秒处理的哀求数。为什么说模糊呢?因为这个数据受实际测试环境,流量场景模式等浩繁因素影响,你很难复现这个测试数据。即便这个20%的性能提升是确实的,其实这个性能提升也并不大,和异步引入的复杂性相比,这20%的提升是否值得是个问题。Netflix本身在其博文22和ppt11中也是有点暗昧其词,甚至自身都有一些疑问的。
Spring Cloud Gateway
原理详见这篇:6000 字 | 16 图 | 深入理解 Spring Cloud Gateway 的原理
SpringCloud Gateway 是 Spring Cloud 的一个全新项目,该项目是基于 Spring 5.0,Spring Boot 2.0 和 Project Reactor 等技术开发的网关,它旨在为微服务架构提供一种简单有效的统一的 API 路由管理方式。
SpringCloud Gateway 作为 Spring Cloud 生态系统中的网关,目的是替代 Zuul,在Spring Cloud 2.0以上版本中,没有对新版本的Zuul 2.0以上最新高性能版本进行集成,仍旧照旧利用的Zuul 2.0之前的非Reactor模式的老版本。而为了提升网关的性能,SpringCloud Gateway是基于WebFlux框架实现的,而WebFlux框架底层则利用了高性能的Reactor模式通信框架Netty。
Spring Cloud Gateway 的目的,不仅提供统一的路由方式,而且基于 Filter 链的方式提供了网关基本的功能,比方:安全,监控/指标,和限流。 Spring Cloud Gateway 底层利用了高性能的通信框架Netty。 SpringCloud Gateway 特性
SpringCloud官方,对SpringCloud Gateway 特性先容如下:
(1)基于 Spring Framework 5,Project Reactor 和 Spring Boot 2.0
(2)集成 Hystrix 断路器
(3)集成 Spring Cloud DiscoveryClient
(4)Predicates 和 Filters 作用于特定路由,易于编写的 Predicates 和 Filters
(5)具备一些网关的高级功能:动态路由、限流、路径重写
从以上的特性来说,和Zuul的特性差别不大。SpringCloud Gateway和Zuul重要的区别,照旧在底层的通信框架上。
简单阐明一下上文中的三个术语: Filter(过滤器)
和Zuul的过滤器在概念上类似,可以利用它拦截和修改哀求,而且对上游的相应,进行二次处理。过滤器为org.springframework.cloud.gateway.filter.GatewayFilter类的实例。 Route(路由)
网关设置的基本组成模块,和Zuul的路由设置模块类似。一个Route模块由一个 ID,一个目的 URI,一组断言和一组过滤器定义。如果断言为真,则路由匹配,目的URI会被访问。 Predicate(断言):
这是一个 Java 8 的 Predicate,可以利用它来匹配来自 HTTP 哀求的任何内容,比方 headers 或参数。断言的输入类型是一个 ServerWebExchange。
网关对比总结