前述:Spring Zuul是Spring微服务的网关,作为微服务的入口,用来统一管理请求。Zuul不是把网关的所有事情都做了,而是暴露了当前请求的整个过程生命周期的处理。实际网关的实现逻辑还是需要我们自己处理,在解析完Zuul后我会提供一个网关限流的方案实例,并对其做扩展,以为大家在实现的时候做参考。
说在前:我认为相比直接上代码怎么实现网关限流来说,先了解原理更有助于我们理解与使用
一、环境描述
解析原理使用查看的的Zuul版本是: Spring Cloud 1.5.4
二、请求处理流程解析
1)Zuul架构图
(摘自:https://blog.csdn.net/forezp/article/details/76211680 ,这篇文章的源码解析还不错,可以阅览下)
网上的源码解析文章很多,我这里就不多做说明了。我这里主要是想尽可能简单、清楚的描述请求的处理流程,在开始之前有必要说明几个关键的类:
- ServletWrappingController :该类的是Spring MVC中的请求封装控制器,负责将请求转给指定的servlet处理。
- ZuulController:Zuul中提供的继承ServletWrappingController的子类,用将请求转到ZuulServlet处理
- ZuulServlet:Zuul网关中网络请求处理器
- ZuulRunner:将HttpServletRequest添加到请求的上下文中
- FilterProcessor:集中处理各生命周期的过滤器
- FilterLoader:存储和加载过滤器的地方
下面就是我整理的请求处理流程:
上图只说明了Zuul在处理请求的流程,让大家知道我们的自定义的过滤器是在何时以及如何被执行的。Zuul其他的部分后面的文章会叙述。
三、Zuul脑图