Zuul和Gateway的区别

1.spring-cloud-Gateway:

        由于目前spring-cloud中引用的还是zuul1.x版本,这个版本是基于过滤器的,是IO式阻塞,同时也不支持长连接,2.x在此基础上性能得到了提升,但是spring-cloud基本上放弃了zuul2.x,这就有了现在的Spring Cloud Gateway。

这里可以看到,最新的spring cloud中的zuul还是1.3.1版本,并且官网已经声明不在维护zuul 

2.API网关

       API网关是一个服务器,是系统的唯一入口。API网关封装了系统内部架构,为每个客户端提供一个定制的API。

        其他职责:

  • 身份验证
  • 监控
  • 负载均衡
  • 缓存
  • 请求分片与管理
  • 静态响应处理

3.API核心:

        所有的客户端和消费端都通过统一的网关接入微服务,在网关层处理所有的非业务功能。通常,网关也是提供REST/HTTP的访问API。

4.网关所具备的功能:

  • 性能:API高可用,负载均衡,容错机制。
  • 安全:权限身份认证、脱敏,流量清洗,后端签名(保证全链路可信调用),黑名单(非法调用的限制)。 
  • 日志:日志记录(spainid,traceid)一旦涉及分布式,全链路跟踪必不可少。    
  • 缓存:数据缓存。 
  • 监控:记录请求响应数据,api耗时分析,性能监控。
  • 限流:流量控制,错峰流控,可以定义多种限流规则。
  • 灰度:线上灰度部署,可以减小风险。
  • 路由:动态路由规则。

目前,比较流行的网关有:Nginx 、 Kong 、Orange,还有微服务网关Zuul 、Spring Cloud Gateway等。

5.特性

  • 基于Spring Framework 5、Project Reactor和Spring Boot 2.0构建
  • 能够在任意请求属性上匹配路由
  • predicates(谓词) 和 filters(过滤器)是特定于路由的
  • 集成了Hystrix断路器
  • 集成了Spring Cloud DiscoveryClient
  • 易于编写谓词和过滤器
  • 请求速率限制
  • 路径重写

相关术语描述: 

  • Route:路由是网关的基本组件。由ID、目标URL、谓词集合、过滤器集合定义而成,若聚合谓词为true,则匹配路由。
  • Predicate :Java8函数谓词。
  • Filter:是GatewayFilter的一个实例,在这里,可以在发送下游请求之前或之后修改请求和响应。

 6.原理:

 

当客户端向Spring Cloud Gateway发出请求后,如果Gateway Handler Mapping确定请求与陆由匹配后将其发送给Gateway Web Handler。Handler运行通过特定于请求于过滤器链发送求情。之后再通过代理请求执行逻辑,并执行所有的pre过滤逻辑,发出代理请求,最终执行post过滤逻辑。

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值