Gateway网关定义
Gateway是Spring Cloud的一个全新的API网关项目,是Spring官方基于Spring 5.0、Spring Boot 2.0、Project Reactor等技术开发的网关。
Gateway网关作用
传统的单体架构中只需要开放一个服务给客户端调用,但是微服务架构中是将一个系统拆分成多个微服务。
每一个微服务都会部署到内网服务器中,或者禁止外部访问这些端口,这是对应用的一种安全保护机制。
因此,我们如果想通过互联网来访问这些服务,需要一个统一的入口:这就Gateway服务网关。
Gateway是用于微服务场景的网关组件,旨在提供一种简单而有效的方法来作为API服务的路由,并为它们提供各种增强功能,例如:安全性,监控和可伸缩性。
Gateway网关功能
Gateway网关是一种简单而有效的方式对API进行路由,以及提供一些强大的过滤器功能,如下图所示:
例如包含上图中的Gateway功能:
- 服务路由;
- 安全认证;
- 流量控制;
- 日志监控;
- 熔断保护等功能。
Gateway网关原理
它的工作原理如下图所示:
客户端将请求发给Spring Cloud Gateway,如果Gateway handle mapping 确定这个请求和一个路由匹配,它将此请求发给 Gateway web handle。
这个 Gateway web handle运行这个请求,通过一个filter chain,这个 filter chain在请求路由前后都能执行。
简单而言就是通过一连串的Filter处理匹配到特定规则Predicates的请求。
所以最主要就是做了两件事:
1)哪些请求可以被它处理,由Predicates决定;
2)如何处理由Filters决定。
Gateway网关流程
Gateway网关流程执行流程,如下图所示:
Gateway网关流程执行流程,大致分为如下6步:
- Gateway Client向Gateway Server发送请求;
- 请求首先会被HttpWebHandlerAdapter进行提取组装成网关上下文;
- 然后网关的上下文会传递到DispatcherHandler,它负责将请求分发给 RoutePredicateHandlerMapping;
- RoutePredicateHandlerMapping负责路由查找,并根据路由断言判断路由是否可用;
- 如果过断言成功,由FilteringWebHandler创建过滤器链并调用;
- 请求会一次经过PreFilter–微服务–PostFilter的方法,最终返回响应。
mikechen睿哥
mikechen睿哥,十余年BAT架构经验,资深技术专家,就职于阿里、淘宝、百度等一线互联网大厂。
关注「mikechen」公众号,获取更多技术干货!
后台回复【面试】即可获取《史上最全阿里Java面试题总结》,后台回复【架构】,即可获取《阿里架构师进阶专题全部合集》