hystrix属性描述



super(Setter
//设置GroupKey 用于dashboard 分组展示
.withGroupKey(HystrixCommandGroupKey.Factory.asKey("Semaphore4UserLotteryLimitingGroup"))
//设置commandKey 用户隔离线程池,不同的commandKey会使用不同的线程池
.andCommandKey(HystrixCommandKey.Factory.asKey("Semaphore4UserLotteryLimitingKey"))
//设置线程池名字的前缀,默认使用commandKey
.andThreadPoolKey(HystrixThreadPoolKey.Factory.asKey("Semaphore4UserLotteryLimitingThreadPoolKey"))
.andCommandPropertiesDefaults(
HystrixCommandProperties.Setter()
// 舱壁隔离策略:信号量隔离策略,通常不会用这个,除非是纯内存操作或者简单的并发控制
.withExecutionIsolationStrategy(HystrixCommandProperties.ExecutionIsolationStrategy.SEMAPHORE)
//设置每组command可以申请的permit最大数
//这个参数和线程池的核心线程数是同样的意义,允许有多少个请求同时请求资源。
.withExecutionIsolationSemaphoreMaxConcurrentRequests(0)
//fallback方法的信号量配置,配置getFallback方法并发请求的信号量,
// 如果请求超过了并发信号量限制,则不再尝试调用getFallback方法,而是快速失败,默认信号量为10
.withFallbackIsolationSemaphoreMaxConcurrentRequests(1)
//是否启用降级处理,如果启用了,则在超时或异常时调用getFallback进行降级处理,默认开启
.withFallbackEnabled(true)
//执行超时时间,默认为1000毫秒,如果命令是线程隔离,且配置了executionIsolationThreadInterruptOnTimeout=true,则执行线程将执行中断处理。
// 如果命令是信号量隔离,则进行终止操作,因为信号量隔离与主线程是在一个线程中执行,其不会中断线程处理
.withExecutionTimeoutInMilliseconds(2000)
//是否启用执行超时机制,默认为true
.withExecutionTimeoutEnabled(true)
//当隔离策略为THREAD时,当执行线程执行超时时,是否进行中断处理,默认为true
.withExecutionIsolationThreadInterruptOnTimeout(true)
)
//设置线程池相关参数,设置了信号量隔离后,线程池配置将变无效,因为信号量隔离策略是基于tomcat或者jetty容器线程做隔离
.andThreadPoolPropertiesDefaults(
HystrixThreadPoolProperties.Setter()
// 配置线程池里的线程数
.withCoreSize(13)
)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值