博客
关于我
(三十九) 跟我学习SpringCloud-Spring Cloud Gateway核心概念和工作原理
阅读量:147 次
发布时间:2019-02-27

本文共 893 字,大约阅读时间需要 2 分钟。

Spring Cloud Gateway是Spring官方基于Spring 5.0、Spring Boot 2.0和Project Reactor等技术开发的网关,旨在为微服务架构提供简单有效的统一API路由管理方式。作为Spring Cloud生态系统中的网关,Spring Cloud Gateway的目标是替代Netflix Zuul,不仅提供统一路由方式,还基于Filter链方式提供网关基本功能,如安全、监控/埋点和限流等。

Spring Cloud Gateway依赖Spring Boot和Spring WebFlux,基于Netty运行。它不能在传统的servlet容器中工作,也不能构建成war包。这意味着它主要用于基于Netty的异步应用场景。

在Spring Cloud Gateway中,核心要素包括Route、Predicate和Filter。

Route是网关的基础元素,由ID、目标URI、断言和过滤器组成。当请求到达网关时,Gateway Handler Mapping通过断言进行路由匹配(Mapping),当断言为真时,匹配到路由。

Predicate是Java 8中提供的一个函数,其输入类型是Spring Framework的ServerWebExchange。它允许开发人员匹配来自HTTP的请求,例如请求头或请求参数。简单来说,它就是匹配条件。

Filter是Gateway中的过滤器,可以在请求发出前后进行一些业务上的处理。

Spring Cloud Gateway的工作原理与Zuul的工作原理相似,但主要区别在于Gateway的Filter只有pre和post两种。其工作流程可以用一个简单的示意图来描述:当客户端向Spring Cloud Gateway发出请求时,如果请求与网关程序定义的路由匹配,则请求会被发送到网关Web处理程序。此时,处理程序会运行特定的请求过滤器链。

过滤器之间用虚线分开的原因是过滤器可能会在发送代理请求的前后执行逻辑。所有pre过滤器逻辑先执行,然后执行代理请求;代理请求完成后,执行post过滤器逻辑。

转载地址:http://roef.baihongyu.com/

你可能感兴趣的文章
Nio ByteBuffer组件读写指针切换原理与常用方法
查看>>
NIO Selector实现原理
查看>>
nio 中channel和buffer的基本使用
查看>>
NISP一级,NISP二级报考说明,零基础入门到精通,收藏这篇就够了
查看>>
Nitrux 3.8 发布!性能全面提升,带来非凡体验
查看>>
NI笔试——大数加法
查看>>
NLP 基于kashgari和BERT实现中文命名实体识别(NER)
查看>>
NLP学习笔记:使用 Python 进行NLTK
查看>>
NLP问答系统:使用 Deepset SQUAD 和 SQuAD v2 度量评估
查看>>
NLP:使用 SciKit Learn 的文本矢量化方法
查看>>
Nmap扫描教程之Nmap基础知识
查看>>
Nmap端口扫描工具Windows安装和命令大全(非常详细)零基础入门到精通,收藏这篇就够了
查看>>
NMAP网络扫描工具的安装与使用
查看>>
NMF(非负矩阵分解)
查看>>
NN&DL4.1 Deep L-layer neural network简介
查看>>
NN&DL4.3 Getting your matrix dimensions right
查看>>
NN&DL4.8 What does this have to do with the brain?
查看>>
No 'Access-Control-Allow-Origin' header is present on the requested resource.
查看>>
NO 157 去掉禅道访问地址中的zentao
查看>>
No Datastore Session bound to thread, and configuration does not allow creation of non-transactional
查看>>