SpringCloud-Zuul-02设计原理

2019-06-22  本文已影响0人  小亮__

Zuul的工作原理

zuul的核心是一系列的filters(过滤器), 其作用可以类比Servlet框架的Filter,或者AOP。Zuul框架可以对过滤器进行动态的加载,编译,运行。

Zuul模块图

模块介绍-RequestContext

Zuul内置了很多的过滤器,这些过滤器帮助我们实现各种功能, 而在Zuul的过滤器之间是通过一个RequestContext的静态类来进行数据传递:

模块介绍-Filter类型

Zuul大部分功能都是通过过滤器来实现的。Zuul中定义了四种标准过滤器类型,这些过滤器类型对应于请求的典型生命周期。

模块介绍-Zuul内置过滤器

SpringCloud默认为Zuul编写了一些过滤器,我们下面来分析一下使用@EnableZuulServer、@EnableZuulProxy这两个注解时,都默认使用了哪些过滤器

@EnableZuulServer注解,框架为我们内置了以下过滤器

pre类型过滤器
- ServletDetectionFilter:该过滤器用于检查请求是否通过Spring Dispatcher。检查后,通过isDispatcherServletRequest设置布尔值。
- FormBodyWrapperFilter:解析表单数据,并为请求重新编码。
- DebugFilter:顾名思义,调试用的过滤器,该过滤器就会把RequestContext.setDebugRouting() 、RequestContext.setDebugRequest() 设为true
    - 开启方法1:设置zuul.debug.request=true 开启
    - 开启方法2:在请求时加上debug=true的参数,例如$ZUUL_HOST:ZUUL_PORT/path?debug=true

route类型过滤器
- SendForwardFilter:该过滤器使用Servlet RequestDispatcher转发请求,转发位置存储在
  RequestContext.getCurrentContext().get("forward.to") 中。可以将路由设置成:
       - zuul.routes.server1.path=/server1/**
       - zuul.routes.server1.url=forward:/server1
  然后访问$ZUUL_HOST:ZUUL_PORT/abc ,观察该过滤器的执行过程

post类型过滤器
- SendResponseFilter:将Zuul所代理的微服务的的响应写入当前响应。

error类型过滤器
- SendErrorFilter:如果RequestContext.getThrowable() 不为null,那么默认就会转发到/error,也可以设置error.path属性修改默认的转发路径。

@EnableZuulProxy注解,包含以上所有的过滤器之外,还增加了以下过滤器

pre类型过滤器
- PreDecorationFilter:该过滤器根据提供的RouteLocator确定路由到的地址,以及怎样去路由。
  该路由器也可为后端请求设置各种代理相关的header。

route类型过滤器
- RibbonRoutingFilter:该过滤器使用Ribbon,Hystrix和可插拔的HTTP客户端发送请求。
  serviceId在RequestContext.getCurrentContext().get("serviceId") 中。
  该过滤器可使用不同的HTTP客户端,例如
    - Apache HttpClient:默认的HTTP客户端
    - Squareup OkHttpClient v3:配置ribbon.okhttp.enabled = true开启,并引入相关依赖
    - Netflix Ribbon HTTP client:设置ribbon.restclient.enabled = true 开启,需要注意的是,
        - 该客户端有一定限制,例如不支持PATCH方法,
        - 它有内置的重试机制。

- SimpleHostRoutingFilter:该过滤器通过Apache HttpClient向指定的URL发送请求。URL在RequestContext.getRouteHost() 中。
上一篇 下一篇

猜你喜欢

热点阅读