routing zuul_SpringCloud入门(八): Zuul 过滤器详解

Zuul 过滤器

zuul 有四种过滤器类型,分别是:

1、Pre:过滤器在请求被路由之前调用。我们可利用这种过滤器实现身份验证、在集群中选择请求的微服务、记录调试信息等;

2、Routing:过滤器将请求路由到微服务。这种过滤器用于构建发送给微服务的请求,并使用Apache HttpClient或Netfilx Ribbon请求微服;

3、Post:过滤器在路由到微服务以后执行。这种过滤器可用来为响应添加标准的HTTP Header、收集统计信息和指标、将响应从微服务发送给客户端;

4、Error:在其他阶段发生错误时执行该过滤器。除了默认的过滤器类型微服务;

zuul 过滤器的执行顺序及生命周期(先执行pre>routing>post 然后再在同类型的过滤器按照order大小执行,越小的越先被执行),如图:

Pre过滤器:

1、ServletDetectionFilter:是最先被执行的过滤器。主要用来检测当前请求是通过Spring的DispatcherServlet处理运行,还是通过ZuulServlet来处理运行的。

2、Servlet30WrapperFilter:是第二个执行的过滤器,会对所有请求生效。主要用来将原始的HttpServletRequest包装成Servlet30RequestWrapper对象;

3、FormBodyWrapperFilter:该过滤器仅对两种类请求生效,第一类是Content-Type为application/x-www-form-urlencoded的请求,第二类是Content-Type为multipart/form-data并且是由Spring的DispatcherServlet处理的请求。主要用来将符合要求的请求体包装成FormBodyRequestWrapper对象;

4、PreDecorationFilter:是pre阶段最后被执行的过滤器。该过滤器会判断当前请求上下文中是否存在forward.to和serviceId参数,如果都不存在,那么它就会执行具体过滤器的操作(如果有一个存在的话,说明当前请求已经被处理过了,因为这两个信息就是根据当前请求的路由信息加载进来的)。主要用来为当前请求做一些预处理,比如:进行路由规则的匹配、在请求上下文中设置该请求的基本信息以及将路由匹配结果等一些设置信息等,这些信息将是后续过滤器进行处理的重要依据,我们可以通RequestContext.getCurrentContext()来访问这些信息。

Routing过滤器:

1、RibbonRoutingFilter:是route阶段第一个执行的过滤器。该过滤器只对请求上下文中存在serviceId参数的请求进行处理,即只对通过serviceId配置路由规则的请求生效。而该过滤器的执行逻辑就是面向服务路由的核心,它通过使用Ribbon和Hystrix来向服务实例发起请求,并将服务实例的请求结果返回;

2、SimpleHostRoutingFilter:是route阶段第二个执行的过滤器。该过滤器只对请求上下文中存在routeHost参数的请求进行处理,即只对通过url配置路由规则的请求生效。而该过滤器的执行逻辑就是直接向routeHost参数的物理地址发起请求,该请求是直接通过httpclient包实现的,而没有使用Hystrix命令进行包装,所以这类请求并没有线程隔离和断路器的保护;

3、SendForwardFilter:是route阶段第三个执行的过滤器。该过滤器只对请求上下文中存在forward.to参数的请求进行处理,即用来处理路由规则中的forward本地跳转配置;

Post过滤器:

1、SendResponseFilter:是post阶段最后执行的过滤器。该过滤器会检查请求上下文中是否包含请求响应相关的头信息、响应数据流或是响应体,只有在包含它们其中一个的时候就会执行处理逻辑。而该过滤器的处理逻辑就是利用请求上下文的响应信息来组织需要发送回客户端的响应内容;

Error过滤器:

1、SendErrorFilter:该过滤器仅在请求上下文中包含error.status_code参数(由之前执行的过滤器设置的错误编码)并且还没有被该过滤器处理过的时候执行。而该过滤器的具体逻辑就是利用请求上下文中的错误信息来组织成一个forward到API网关/error错误端点的请求来产生错误响应;

如何自定义过滤器

importcom.netflix.zuul.ZuulFilter;importcom.netflix.zuul.context.RequestContext;importcom.netflix.zuul.exception.ZuulException;importorg.springframework.stereotype.Component;importjavax.servlet.http.HttpServletRequest;import staticorg.springframework.cloud.netflix.zuul.filters.support.FilterConstants.PRE_TYPE;

@Componentpublic class CustomFilter extendsZuulFilter {

@OverridepublicString filterType() {returnPRE_TYPE;

}

@Overridepublic intfilterOrder() {return 0;

}

@Overridepublic booleanshouldFilter() {return true;

}

@Overridepublic Object run() throwsZuulException {

System.out.println("通过自定义的路由器.......");

RequestContext ctx=RequestContext.getCurrentContext();

HttpServletRequest request=ctx.getRequest();return null;

}

}

备注:ctx 在往前台返回内容时中文会出现乱码,ctx.getResponse().setContentType("text/html;charset=UTF-8");

如何禁用过滤器

zuul.CustomFilter.pre.disable = true

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值