Hystrix属性4种优先级

2024-05-30 19:08
文章标签 优先级 属性 hystrix

本文主要是介绍Hystrix属性4种优先级,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Hystrix属性4种优先级

  1. 内置全局 
    • 采用ConcurrentHashMap 有 HystrixCommandProperties HystrixThreadPoolProperties HystrixCollapserProperties
  2. 动态全局 
    • HystrixDynamicProperty
  3. 实例
  4. 动态实例

Hystrix属性

Command Properties 相关类 HystrixCommand

1.执行相关 控制HystrixCommand.run() 执行
  1. 执行的隔离策略: 
    • execution.isolation.strategy
    • 线程池隔离:THREAD
    • 信号量隔离:SEMAPHORE
    • 默认THREAD
    • 信号量适用于接口并发量高的情况,如每秒数百次调用的情况,导致的线程开销过高,通常只适用于非网络调用,执行速度快
  2. 超时时间: 
    • execution.isolation.thread.timeoutInMilliseconds
    • 默认1000毫秒
    • 超过该时间会执行回退逻辑
  3. 是否启用超时设置 
    • execution.timeout.enabled
    • 默认true
  4. 是否超时中断正在执行的run 
    • execution.isolation.thread.interruptOnTimeout
    • 默认true
  5. 是否执行取消动作时,中断正在执行的run 
    • execution.isolation.thread.interruptOnCancel
    • 默认false
  6. 设置最大的信号量,只对于使用信号量[SEMAPHORE]策略的生效 
    • execution.isolation.semaphore.maxConcurrentRequests
    • 默认10
    • 如果超出该并发量,则超出的会被拒绝;且该值必需小于容器的线程池大小,否则并不起保护作用,因为其实容器线程池的一小部分而已
2. 回退 控制HystrixCommand.getFallback() 执行 对于线程池或者信号量执行策略都生效
  1. 最大的并发调用getFallback() 
    • fallback.isolation.semaphore.maxConcurrentRequests
    • 默认10
    • 如果超出该数,则后续的会被拒绝,如果没有实现回退逻辑的,则会抛出异常
  2. 是否当故障或者拒绝发生后,一个调用尝试调用getFallback()方法 
    • fallback.enabled
    • 默认true
3. 断路器 控制HystrixCircuitBreaker
  1. 是否开启断路器用于健康监控和短路请求 
    • circuitBreaker.enabled
    • 默认true
  2. 设置一个窗口内的请求数,当在该窗口内(即时间内)请求数达到了该值,则断路器会被打开 
    • circuitBreaker.requestVolumeThreshold
    • 默认20
  3. 设置在断路打开后,拒绝请求到再次尝试请求并决定断路器是否继续打开的时间 
    • circuitBreaker.sleepWindowInMilliseconds
    • 默认5000毫秒
  4. 设置打开断路器并走回退逻辑的错误率 
    • circuitBreaker.errorThresholdPercentage
    • 默认50%
  5. 是否强制打开断路器,如果打开则会拒绝左右的请求 
    • circuitBreaker.forceOpen
    • 默认false
    • 优先级比circuitBreaker.forceClosed高
  6. 是否强制关闭断路器,则允许所有的请求,无视错误率 
    • circuitBreaker.forceClosed
    • 默认false
4. 度量 主要度量HystrixCommand 和 HystrixObservableCommand 的执行情况
  1. 设置滚动窗口的统计时间 
    • metrics.rollingStats.timeInMilliseconds
    • 默认10000毫秒
    • 该项不可以动态修改,以防止统计的不正确
  2. 设置滚动的统计窗口被分成的桶的数量 
    • metrics.rollingStats.numBuckets
    • 默认10
    • metrics.rollingStats.timeInMilliseconds % metrics.rollingStats.numBuckets == 0 这个必须成立,否则会抛异常
  3. 是否开启百分数和均值统计 
    • metrics.rollingPercentile.enabled
    • 默认true
    • 如果为false,则值为-1
  4. 设置滚动窗口的持续时间,其中执行时间保持在百分位数中 
    • metrics.rollingPercentile.timeInMilliseconds
    • 默认60000
  5. numBuckets 
    • metrics.rollingPercentile.numBuckets
    • 默认6
  6. bucketSize 
    • metrics.rollingPercentile.bucketSize
    • 默认100
  7. intervalInMilliseconds 
    • metrics.healthSnapshot.intervalInMilliseconds
    • 默认500
5. 请求上下文 控制HystrixRequestContext 被HystrixCommand使用
  1. 是否启动当HystrixCommand.getCacheKey()调用后,缓存到HystrixRequestCache 
    • requestCache.enabled
    • 默认true
  2. 是否记录HystrixCommand执行或者事件的日志到HystrixRequestLog 
    • requestLog.enabled
    • 默认true

Collapser Properties 控制HystrixCollapser

  1. 设置在批处理请求中,允许的最大请求数 
    • maxRequestsInBatch
    • 默认Integer.MAX_VALUE
  2. 设置批处理在多少毫秒后出发执行 
    • timerDelayInMilliseconds
    • 默认10毫秒
  3. 是否缓存HystrixCollapser.execute() 和 HystrixCollapser.queue() 
    • requestCache.enabled
    • 默认true

Thread Pool Properties 控制执行的线程池

  1. 执行线程数 
    • coreSize
    • 默认10
  2. 最大执行线程数 通常同1一样大小 
    • maximumSize
    • 默认10
  3. 设置使用哪种BlockingQueue,如果-1为SynchronousQueue;其他则为LinkedBlockingQueue 
    • maxQueueSize
    • 默认-1
    • 不支持动态调整
  4. 设置拒绝队列大小,这个属性是因为maxQueueSize无法动态改变,但需要去动态改变队列大小 
    • queueSizeRejectionThreshold
    • 默认5
    • 当maxQueueSize为-1,则该属性不可用
  5. 设置线程存活多少毫秒 
    • keepAliveTimeMinutes
    • 默认1
  6. 设置maximumSize启作用 
    • allowMaximumSizeToDivergeFromCoreSize
    • 默认false
  7. 滚动窗口 
    • metrics.rollingStats.timeInMilliseconds
    • 默认10000毫秒
  8. 设置桶数 必需metrics.rollingStats.timeInMilliseconds % metrics.rollingStats.numBuckets == 0 否则抛异常 
    • metrics.rollingStats.numBuckets
    • 默认10

这篇关于Hystrix属性4种优先级的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1016742

相关文章

CSS3中的字体及相关属性详解

《CSS3中的字体及相关属性详解》:本文主要介绍了CSS3中的字体及相关属性,详细内容请阅读本文,希望能对你有所帮助... 字体网页字体的三个来源:用户机器上安装的字体,放心使用。保存在第三方网站上的字体,例如Typekit和Google,可以link标签链接到你的页面上。保存在你自己Web服务器上的字

SpringBoot读取ZooKeeper(ZK)属性的方法实现

《SpringBoot读取ZooKeeper(ZK)属性的方法实现》本文主要介绍了SpringBoot读取ZooKeeper(ZK)属性的方法实现,强调使用@ConfigurationProperti... 目录1. 在配置文件中定义 ZK 属性application.propertiesapplicati

Java反射实现多属性去重与分组功能

《Java反射实现多属性去重与分组功能》在Java开发中,​​List是一种非常常用的数据结构,通常我们会遇到这样的问题:如何处理​​List​​​中的相同字段?无论是去重还是分组,合理的操作可以提高... 目录一、开发环境与基础组件准备1.环境配置:2. 代码结构说明:二、基础反射工具:BeanUtils

MySQL 事务的概念及ACID属性和使用详解

《MySQL事务的概念及ACID属性和使用详解》MySQL通过多线程实现存储工作,因此在并发访问场景中,事务确保了数据操作的一致性和可靠性,下面通过本文给大家介绍MySQL事务的概念及ACID属性和... 目录一、什么是事务二、事务的属性及使用2.1 事务的 ACID 属性2.2 为什么存在事务2.3 事务

Spring Cache注解@Cacheable的九个属性详解

《SpringCache注解@Cacheable的九个属性详解》在@Cacheable注解的使用中,共有9个属性供我们来使用,这9个属性分别是:value、cacheNames、key、key... 目录1.value/cacheNames 属性2.key属性3.keyGeneratjavascriptor

Spring Boot 事务详解(事务传播行为、事务属性)

《SpringBoot事务详解(事务传播行为、事务属性)》SpringBoot提供了强大的事务管理功能,通过@Transactional注解可以方便地配置事务的传播行为和属性,本文将详细介绍Spr... 目录Spring Boot 事务详解引言声明式事务管理示例编程式事务管理示例事务传播行为1. REQUI

Nginx路由匹配规则及优先级详解

《Nginx路由匹配规则及优先级详解》Nginx作为一个高性能的Web服务器和反向代理服务器,广泛用于负载均衡、请求转发等场景,在配置Nginx时,路由匹配规则是非常重要的概念,本文将详细介绍Ngin... 目录引言一、 Nginx的路由匹配规则概述二、 Nginx的路由匹配规则类型2.1 精确匹配(=)2

Spring Security基于数据库的ABAC属性权限模型实战开发教程

《SpringSecurity基于数据库的ABAC属性权限模型实战开发教程》:本文主要介绍SpringSecurity基于数据库的ABAC属性权限模型实战开发教程,本文给大家介绍的非常详细,对大... 目录1. 前言2. 权限决策依据RBACABAC综合对比3. 数据库表结构说明4. 实战开始5. MyBA

CSS will-change 属性示例详解

《CSSwill-change属性示例详解》will-change是一个CSS属性,用于告诉浏览器某个元素在未来可能会发生哪些变化,本文给大家介绍CSSwill-change属性详解,感... will-change 是一个 css 属性,用于告诉浏览器某个元素在未来可能会发生哪些变化。这可以帮助浏览器优化

浅析CSS 中z - index属性的作用及在什么情况下会失效

《浅析CSS中z-index属性的作用及在什么情况下会失效》z-index属性用于控制元素的堆叠顺序,值越大,元素越显示在上层,它需要元素具有定位属性(如relative、absolute、fi... 目录1. z-index 属性的作用2. z-index 失效的情况2.1 元素没有定位属性2.2 元素处