Spring Cloud---Zuul网关篇( 一)-----Zuul请求流程解析(简化)

时间:2024-03-12 22:00:25

前述:Spring Zuul是Spring微服务的网关,作为微服务的入口,用来统一管理请求。Zuul不是把网关的所有事情都做了,而是暴露了当前请求的整个过程生命周期的处理。实际网关的实现逻辑还是需要我们自己处理,在解析完Zuul后我会提供一个网关限流的方案实例,并对其做扩展,以为大家在实现的时候做参考。

说在前:我认为相比直接上代码怎么实现网关限流来说,先了解原理更有助于我们理解与使用

一、环境描述

解析原理使用查看的的Zuul版本是: Spring Cloud  1.5.4 

二、请求处理流程解析

1)Zuul架构图

  (摘自:https://blog.csdn.net/forezp/article/details/76211680 ,这篇文章的源码解析还不错,可以阅览下)

                                         Spring Cloud---Zuul网关篇( 一)-----Zuul请求流程解析(简化)

 

网上的源码解析文章很多,我这里就不多做说明了。我这里主要是想尽可能简单、清楚的描述请求的处理流程,在开始之前有必要说明几个关键的类:

  • ServletWrappingController :该类的是Spring MVC中的请求封装控制器,负责将请求转给指定的servlet处理。
  • ZuulController:Zuul中提供的继承ServletWrappingController的子类,用将请求转到ZuulServlet处理
  • ZuulServlet:Zuul网关中网络请求处理器
  • ZuulRunner:将HttpServletRequest添加到请求的上下文中
  • FilterProcessor:集中处理各生命周期的过滤器
  • FilterLoader:存储和加载过滤器的地方

下面就是我整理的请求处理流程:

                Spring Cloud---Zuul网关篇( 一)-----Zuul请求流程解析(简化)

上图只说明了Zuul在处理请求的流程,让大家知道我们的自定义的过滤器是在何时以及如何被执行的。Zuul其他的部分后面的文章会叙述。

三、Zuul脑图

Spring Cloud---Zuul网关篇( 一)-----Zuul请求流程解析(简化)