Spring Cloud微服务之网关zuul配置项详解

一,Zuul的应用场景


Zuul是Netflix基于JVM的路由器和服务器端负载均衡器。


Zuul可以通过加载动态过滤机制,从而实现以下各项功能:

验证与安全保障:识别面向各类资源的验证要求并拒绝那些与要求不符的请求。

审查与监控:在边缘位置追踪有意义数据及统计结果,从而为我们带来准确的生产状态结论。

动态路由:以动态方式根据需要将请求路由至不同后端集群。

压力测试:逐渐增加指向集群的负载流量,从而计算性能水平。

负载分配:为每一种负载类型分配对应容量,并弃用超出限定值的请求。

静态响应处理:在边缘位置直接建立部分响应,从而避免其流入内部集群。

多区域弹性::跨越AWS区域进行请求路由,旨在实现ELB使用多样化并保证边缘位置与使用者尽可能接近。


Zuul的规则引擎允许任何JVM语言编写规则和过滤器,内置支持Java和Groovy。


二,Zuul的配置文件详解


1,超时时间配置

Spring Cloud因为整合了zuul,ribbon,hystrix,所以超时时间也比较复杂,到底使用哪个超时时间配置,我们来看一下。

zuul的超时时间配置:

zuul.host.socket-timeout-millis

zuul.host.connect-timeout-millis

ribbon的超时时间配置:

ribbon.ConnectTimeout

ribbon.ReadTimeout

hystrix的超时时间配置:

hystrix.command.default.execution.

isolation.thread.timeoutInMillisecond


如果我们既设置了ribbon的超时时间,又设置了hystrix的超时时间,那么zuul最终会取较小的那个值。


2,host最大连接数配置

zuul.host.maxTotalConnections:最大连接数。默认值是200,我们项目配置的是2000。

zuul.host.maxPreRouteConnections:每个路由的最大连接数。默认20,我们项目配置的是500。


3,路由配置

zuul.routes.微服务.path:请求转发路径,也就是说zuul会把带有当前的请求转发到对应的名称为serviceId的微服务上。

zuul.routes.微服务.serviceId:微服务的唯一标识。

zuul.routes.微服务.stripPrefix:是否去掉前缀。这个配置是配合zuul.prefix来使用的,如果我们设置了前缀,可以通过设置stripPrefix=true来自动去掉前缀。

zuul.routes.xxx.url:配置反向代理。

zuul.routes.微服务.sensitive-headers:过滤掉客户端附带的headers相关属性。Zuul默认会过滤掉下面三个属性:

Cookies

Set-Cookie

Authorization

具体可以参考源码:ZuulProperties


zuul.routes.微服务.ignored-headers:

具体可以参考源码:ZuulProperties。


4,hystrix相关配置


#hystrix的隔离策略

hystrix.command.default.execution.isolation.strategy=THREAD

Hystrix的隔离策略有两种:分别是线程隔离和信号量隔离。

THREAD(线程隔离):使用该方式,HystrixCommand将会在单独的线程上执行,并发请求受线程池中线程数量的限制。

SEMAPHORE(信号量隔离):使用该方式,HystrixCommand将会在调用线程上执行,开销相对较小,并发请求受信号量的个数的限制。

Hystrix中默认并且推荐使用线程隔离,因为这种方式有一个除网络超时以外的额外保护层。

一般来说,只有当调用负载非常高时(例如每个实例每秒调用数百次)才需要使用信号量隔离,因为这种场景下使用THREAD开销会比较高。信号量隔离一般仅适用于非网络调用的隔离。


#设置HystrixCommand的执行是否有超时限制。

hystrix.command.default.execution.timeout.enabled=false


#等待hystrix命令执行的超时时间

hystrix.command.default.execution.isolation.thread.timeoutInMillisecond=90000

设置调用者等待命令执行的超时限制,超过此时间,HystrixCommand被标记为TIMEOUT,并执行回退逻辑。

注意:超时会作用在HystrixCommand.queue(),即使调用者没有调用get()去获得Future对象。


#HystrixCommand执行方法允许的最大请求数。

hystrix.command.default.fallback.isolation.semaphore.maxConcurrentRequest=200

设置当使用ExecutionIsolationStrategy.SEMAPHORE时,HystrixCommand执行方法允许的最大请求数。如果达到最大并发数时,后续请求会被拒绝。信号量应该是容器(比如Tomcat)线程池一小部分,不能等于或者略小于容器线程池大小,否则起不到保护作用。


#设置断路器是否生效

hystrix.command.default.circuitBreaker.enabled=true


#是否强制打开断路器

hystrix.command.default.circuitBreaker.forceOpen=false

如果该属性设置为true,强制断路器进入打开状态,将会拒绝所有的请求。该属性优先级比circuitBreaker.forceClosed高。


#是否强制关闭断路器

hystrix.command.default.circuitBreaker.forceClosed=false

如果该属性设置为true,强制断路器进入关闭状态,将会允许所有的请求,无视错误率。


#线程池核心线程数

hystrix.threadpool.default.coreSize=2000

这里的coreSize和ThreadPoolExecutor的corePoolSize是不同的概念。hystrix会对请求进行隔离,这个隔离是通过线程池来实现的。hystrix会根据调用的服务,对线程池进行重新划分,这个coreSize是hystrix划分的线程池的核心线程数。


#最大信号量

zuul.semaphore.max-semaphore=5000

设置当使用ExecutionIsolationStrategy.SEMAPHORE时,信号量的最大值。


三,Zuul的隔离模式


准确的说,Zuul没有隔离模式,我们这里的隔离模式本质上是Hystrix的隔离模式,在Spring Cloud体系中,Zuul默认整合了Hystrix。

在Hystrix的jar包下,有一个HystrixCommandProperties,这个类中定义了2个隔离级别:SEMAPHORE和THREAD,默认使用SEMAPHORE。

SEMAPHORE:信号量隔离级别。

THREAD:线程池隔离级别。


这2种隔离级别有何区别呢?

THREAD(线程隔离):使用该方式,HystrixCommand将会在单独的线程上执行,并发请求受线程池中线程数量的限制。

SEMAPHORE(信号量隔离):使用该方式,HystrixCommand将会在调用线程上执行,开销相对较小,并发请求受信号量的个数的限制。

Hystrix中默认并且推荐使用线程隔离,因为这种方式有一个除网络超时以外的额外保护层。

一般来说,只有当调用负载非常高时(例如每个实例每秒调用数百次)才需要使用信号量隔离,因为这种场景下使用THREAD开销会比较高。信号量隔离一般仅适用于非网络调用的隔离。


四,Zuul架构图


图片发自简书App


这里简单总结一下Zuul的工作原理。

1,ZuulServlet

ZuulServlet是Zuul的入口。ZuulServlet继承了抽象类HttpServlet,把HttpServlet包装成ZuulServlet。ZuulServlet实现了GenericServlet的init()方法,并且实现了HttpServlet的service()方法。

也就是说,ZuulServlet具备了为Zuul提供服务的能力,通过ZuulServlet.service(),ZuulServlet可以开启Zuul服务了!


2,ZuulRunner

ZuulServlet最终会把请求交给ZuulRunner,由ZuulRunner来执行具体的逻辑。

ZuulRunner做了什么呢?ZuulRunner拿到RequestContext,然后设置了HttpServletRequest和HttpServletResponse就完事了。然后把请求交给FilterProcessor。


3,FilterProcessor

FilterProcessor是过滤器的最终执行者。


4,FilterLoader

FilterLoader借助FilterRegistry,实现了获取查询和新增过滤器的功能。有一点需要注意,如果拿到的ZuulFilter为空,FilterLoader会尝试使用GroovyCompiler加载ZuulFilter。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352