Gateway网关详解(作用功能及原理流程)

Gateway网关详解(作用功能及原理流程)-mikechen

Gateway网关定义

Gateway是Spring Cloud的一个全新的API网关项目,是Spring官方基于Spring 5.0、Spring Boot 2.0、Project Reactor等技术开发的网关。

 

Gateway网关作用

传统的单体架构中只需要开放一个服务给客户端调用,但是微服务架构中是将一个系统拆分成多个微服务。

每一个微服务都会部署到内网服务器中,或者禁止外部访问这些端口,这是对应用的一种安全保护机制。

因此,我们如果想通过互联网来访问这些服务,需要一个统一的入口:这就Gateway服务网关。

Gateway是用于微服务场景的网关组件,旨在提供一种简单而有效的方法来作为API服务的路由,并为它们提供各种增强功能,例如:安全性,监控和可伸缩性。

 

Gateway网关功能

Gateway网关是一种简单而有效的方式对API进行路由,以及提供一些强大的过滤器功能,如下图所示:

Gateway网关详解(作用功能及原理流程)-mikechen

例如包含上图中的Gateway功能:

  1. 服务路由;
  2. 安全认证;
  3. 流量控制;
  4. 日志监控;
  5. 熔断保护等功能。

 

Gateway网关原理

它的工作原理如下图所示:

Gateway网关详解(作用功能及原理流程)-mikechen

客户端将请求发给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网关详解(作用功能及原理流程)-mikechen

Gateway网关流程执行流程,大致分为如下6步:

  1. Gateway Client向Gateway Server发送请求;
  2. 请求首先会被HttpWebHandlerAdapter进行提取组装成网关上下文;
  3. 然后网关的上下文会传递到DispatcherHandler,它负责将请求分发给 RoutePredicateHandlerMapping;
  4. RoutePredicateHandlerMapping负责路由查找,并根据路由断言判断路由是否可用;
  5. 如果过断言成功,由FilteringWebHandler创建过滤器链并调用;
  6. 请求会一次经过PreFilter–微服务–PostFilter的方法,最终返回响应。

 

陈睿mikechen

10年+大厂架构经验,资深技术专家,就职于阿里巴巴、淘宝、百度等一线互联网大厂。

关注「mikechen」公众号,获取更多技术干货!

后台回复面试即可获取《史上最全阿里Java面试题总结》,后台回复架构,即可获取《阿里架构师进阶专题全部合集

评论交流
    说说你的看法