hystrix 实践


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
* 设置开启断路器 在滚动时间

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

叫我三师弟

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值