hystrix 线程池隔离下 传递请求上下文数据
ThreadLocal / RequestContextHolder 无法跨线程传递数据
官方推荐通过实现 HystrixConcurrencyStrategy 来完成数据跨线程传递
1.改写 wrapCallable 方法,通过 Callable 来封装请求上下文数据
2.在实现类构造器中通过 HystrixPlugins 注册该并发策略
HystrixPlugins.getInstance().registerConcurrencyStrategy(this);
需兼容已有策略
构造器中注册该并发策略前,先保存已有并发策略,并通过 get 方法返回相关信息
客户端
1.jar 包导入
spring-cloud-starter-netflix-hystrix
2.配置启动类
@EnableHystrix
3.代码使用
配置 @HystrixCommand 及异常降级方法 fallbackMethod
/**
* commandKey 全局唯一标识,默认为方法名
* groupKey 全局唯一标识服务分组名称,用于统计数据,默认的线程池划分是根据服务分组名称进行
* threadPoolKey 设置服务线程池信息,用于 HystrixThreadPool 监控
* fallbackMethod 降级方法,必须和 @HystrixCommand 配置的方法在同一个类中,方法的参数要保持一致
* ignoreExceptions 不走降级的异常
* Command 属性 execution.isolation.strategy 执行的隔离策略
* THREAD 线程池隔离策略 独立线程接收请求
* SEMAPHORE 信号量隔离策略 在调用线程上执行
* 隔离策略为信号量的时候,该属性来配置信号量的大小,默认值 10,最大并发达到信号量时,后续请求被拒绝
* execution.isolation.semaphore.maxConcurrentRequests
* 设置 HystrixCommand 执行的超时时间,单位毫秒,默认 1000,通常 5 - 10 s
* execution.isolation.thread.timeoutInMilliseconds
* 是否启动超时时间,默认 true
* execution.timeout.enabled
* 超时时是否中断执行
* execution.isolation.thread.interruptOnTimeout
* 是否开启断路器功能
* circuitBreaker.enabled
* 设置在滚动时间窗口中,断路器的最小请求数。默认 20
* circuitBreaker.requestVolumeThreshold
* 设置当断路器打开之后的休眠时间,过了睡眠时间窗后,断路器转为半开状态,并为后续的一条请求放行,
* 如果请求返回成功,熔断器就变成关闭状态,如果请求失败,熔断器就变成开启状态
* circuitBreaker.sleepWindowInMilliseconds
* 设置开启断路器 在滚动时间