SpringCloud入门之Zuul拦截器

Cookie与头信息

默认情况下,Zuul在请求路由时,会过滤HTTP请求头信息中的一些敏感信息,默认的敏感头信息通过zuul.sensitiveHeaders定义,包括Cookie、Set-Cookie、Authorization。
zuul:
sensitiveHeaders: # 使用空来覆盖默认值

	zuul:
		routes:
			[route]:
				customSensitiveHeaders: true # 对指定路由开启自定义敏感头

	zuul:
		routes:
			[route]:
				sensitiveHeaders: # 对指定路由的敏感头设置为空

Zuul拦截器
用来实现对外服务的控制。filter的生命周期有4个,分别是”pre”、”route”、”post”、”error”,整个生命周期可以用下图来表示。

5.1zuul中默认实现的filter

类型 顺序 过滤器 功能
pre -3 ServletDetectionFilter 标记处理Servlet的类型
pre -2 Servlet30WrapperFilter 包装HttpServletRequest请求
pre -1 FormBodyWrapperFilter 包装请求体
route 1 DebugFilter 标记调试标志
route 5 PreDecorationFilter 处理请求上下文供后续使用
route 10 RibbonRoutingFilter serviceId请求转发
route 100 SimpleHostRoutingFilter url请求转发
route 500 SendForwardFilter forward请求转发
post 0 SendErrorFilter 处理有错误的请求响应
post 1000 SendResponseFilter 处理正常的请求响应

5.2禁用指定的filter
可以在application.yml中配置需要禁用的filter,格式:zuul:[filter-name]:[filter-type]:disable:true。

zuul:
FormBodyWrapperFilter:
pre:
disable: true
5.3 自定义filter
使用java实现自定义filter,需要添加继承于ZuulFilter的类,覆盖其中的4个方法

public class CustomerPreFilter extends ZuulFilter {
@Override
String filterType() {
return “pre”; //定义filter的类型,有pre、route、post、error四种
}

@Override
int filterOrder() {
    return 10; //定义filter的顺序,数字越小表示顺序越高,越先执行
}

@Override
boolean shouldFilter() {
    return true; //表示是否需要执行该filter,true表示执行,false表示不执行
}

@Override
Object run() {
    return null; //filter需要执行的具体操作
}

}

八、性能优化参考
在application.yml文件中配置线程数、缓冲大小

server:
tomcat:
max-threads: 128 # 最大worker线程
min-spare-threads: 64 # 最小worker线程
undertow:
io-threads: 8 # IO线程数,默认为CPU核心数,最小为2
worker-threads: 40 # 阻塞任务线程池,值设置取决于系统的负载,默认为io-threads * 8
buffer-size: 512 # 每块buffer的空间大小
buffers-per-region: 10 # 每个区分配的buffer数量
direct-buffers: 512 # 是否分配的直接内存
在application.yml文件中配置zuul和ribbon

zuul:
host:
max-total-connections: 500 # 每个服务的http客户端连接池最大连接,默认值是200
max-per-route-connections: 50 # 每个route可用的最大连接数,默认值是20
ribbon-isolation-strategy: THREAD # 可选:SEMAPHORE THREAD
在application.yml文件中配置hystrix

hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds 设置thread的默认超时时间,默认值是10000。

hystrix.command.[CommandKey].execution.isolation.thread.timeoutInMilliseconds 设置不同微服务的超时时间

猜你喜欢

转载自blog.csdn.net/qq_36755772/article/details/88954417