SpringBoot集成Hystrix

Hystrix配置

Hystrix配置参数讲解:

对Hystrix服务降级和熔断进行测试,3个例子。

当访问http://localhost:8082/hystrix1/test1抛出异常,服务降级返回fail1。
当访问http://localhost:8082/hystrix1/test2抛出异常,服务不断降级返回default fail。

当访问1次http://localhost:8082/hystrix2/test1?id=1和2次http://localhost:8082/hystrix2/test1?id=2,错误率达66%超过了设置的50%。服务进入熔断。

下次请求http://localhost:8082/hystrix2/test1?id=2会进入熔断策略,返回default fail

如果在5s之后,下一次请求成功,会关闭熔断,服务恢复。


.\ab -c 30 -n 30 http://localhost:8082/hystrix3/test1并发30个请求。

由于没有显式配置maxQueueSize。Hystrix不会向阻塞队列里面放任务。当任务的数量超过了线程池负载的阈值,会采用拒绝任务策略。核心线程数量+初始数量=11个线程。11个线程由于线程阻塞进入了Timeout状态,后续无法正常继续执行其他任务,采取拒绝任务策略(拒绝了30-11=19个任务)。

此时服务进入到熔断状态,在5s之后,我们再发送http://localhost:8082/hystrix3/test1请求,发现还是处于timeout状态,依旧是失败,继续保持熔断状态。

后续再发送http://localhost:8082/hystrix3/test1请求,该请求已经进入到熔断处理。

maxQueueSize:作业队列的最大值,默认值为 -1,设置为此值时,队列会使用 SynchronousQueue,此时其 size 为0。
Hystrix 不会向队列内存放作业。如果此值设置为一个正的 int 型,队列会使用一个固定 size 的 LinkedBlockingQueue。
此时在核心线程池内的线程都在忙碌时,会将作业暂时存放在此队列内,但超出此队列的请求依然会被拒绝。

queueSizeRejectionThreshold:由于 maxQueueSize 值在线程池被创建后就固定了大小,
如果需要动态修改队列长度的话可以设置此值,
即使队列未满,队列内作业达到此值时同样会拒绝请求。
此值默认是 5,所以有时候只设置了 maxQueueSize 也不会起作用。

.\ab -c 100 -n 100 http://localhost:8082/hystrix3/test2并发100个请求。核心线程数是15个,加上初始的1个。核心线程数应该是16个,阻塞队列里面有15个。所以executions为31个。当线程数超过了阻塞队列的阈值,就拒绝任务,所以Rejected的数量是100-31=69个。默认情况下,在滑动窗口内,请求数量超过了20个,才计算熔断错误比率。当熔断错误比率超过了50%,采用熔断策略。

转自:https://www.jianshu.com/p/5b48eebf4f38

发表回复