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

相关文章

Java如何通过反射机制获取数据类对象的属性及方法

《Java如何通过反射机制获取数据类对象的属性及方法》文章介绍了如何使用Java反射机制获取类对象的所有属性及其对应的get、set方法,以及如何通过反射机制实现类对象的实例化,感兴趣的朋友跟随小编一... 目录一、通过反射机制获取类对象的所有属性以及相应的get、set方法1.遍历类对象的所有属性2.获取

vue如何监听对象或者数组某个属性的变化详解

《vue如何监听对象或者数组某个属性的变化详解》这篇文章主要给大家介绍了关于vue如何监听对象或者数组某个属性的变化,在Vue.js中可以通过watch监听属性变化并动态修改其他属性的值,watch通... 目录前言用watch监听深度监听使用计算属性watch和计算属性的区别在vue 3中使用watchE

滚雪球学Java(87):Java事务处理:JDBC的ACID属性与实战技巧!真有两下子!

咦咦咦,各位小可爱,我是你们的好伙伴——bug菌,今天又来给大家普及Java SE啦,别躲起来啊,听我讲干货还不快点赞,赞多了我就有动力讲得更嗨啦!所以呀,养成先点赞后阅读的好习惯,别被干货淹没了哦~ 🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,助你一臂之力,带你早日登顶🚀,欢迎大家关注&&收藏!持续更新中,up!up!up!! 环境说明:Windows 10

web群集--nginx配置文件location匹配符的优先级顺序详解及验证

文章目录 前言优先级顺序优先级顺序(详解)1. 精确匹配(Exact Match)2. 正则表达式匹配(Regex Match)3. 前缀匹配(Prefix Match) 匹配规则的综合应用验证优先级 前言 location的作用 在 NGINX 中,location 指令用于定义如何处理特定的请求 URI。由于网站往往需要不同的处理方式来适应各种请求,NGINX 提供了多种匹

HTML5自定义属性对象Dataset

原文转自HTML5自定义属性对象Dataset简介 一、html5 自定义属性介绍 之前翻译的“你必须知道的28个HTML5特征、窍门和技术”一文中对于HTML5中自定义合法属性data-已经做过些介绍,就是在HTML5中我们可以使用data-前缀设置我们需要的自定义属性,来进行一些数据的存放,例如我们要在一个文字按钮上存放相对应的id: <a href="javascript:" d

Python中的属性装饰器:解锁更优雅的编程之道

引言 在Python的世界里,装饰器是一个强大的工具,它允许我们以一种非侵入性的方式修改函数或方法的行为。而当我们谈论“属性装饰器”时,则是在探讨如何使用装饰器来增强类中属性的功能。这不仅让我们的代码更加简洁、易读,同时也提供了强大的功能扩展能力。本文将带你深入了解属性装饰器的核心概念,并通过一系列实例展示其在不同场景下的应用,从基础到进阶,再到实际项目的实战经验分享,帮助你解锁Python编程

react笔记 8-17 属性绑定 class绑定 引入图片 循环遍历

1、绑定属性 constructor(){super()this.state={name:"张三",title:'我是一个title'}}render() {return (<div><div>aaaaaaa{this.state.name}<div title={this.state.title}>我是一个title</div></div></div>)} 绑定属性直接使用花括号{}   注

ConstraintLayout布局里的一个属性app:layout_constraintDimensionRatio

ConstraintLayout 这是一个约束布局,可以尽可能的减少布局的嵌套。有一个属性特别好用,可以用来动态限制宽或者高app:layout_constraintDimensionRatio 关于app:layout_constraintDimensionRatio参数 app:layout_constraintDimensionRatio=“h,1:1” 表示高度height是动态变化

Python中的私有属性与方法:解锁面向对象编程的秘密

在Python的广阔世界里,面向对象编程(OOP)是一种强大而灵活的方法论,它帮助我们更好地组织代码、管理状态,并构建可复用的软件组件。而在这个框架内,私有属性与方法则是实现封装的关键机制之一。它们不仅有助于隐藏类内部的具体实现细节,还能保护数据免受外部干扰。今天,让我们一起探索Python中私有属性与方法的魅力所在,了解它们如何在实际开发中发挥重要作用。 引言 随着软件系统变得越来越复杂,维

转:android ro.debuggable属性调试修改(mprop逆向)

android ro属性调试修改(mprop逆向)      大家都知道如果需要调试android 的程序,以下两个条件满足一个就行。第一是apk的配置文件内的AndroidManifest.xml的 android:debuggable=”true”,第二就是/default.prop中ro.debuggable=1。两种方式第一种通常是解包添加属性再打包,随着加壳软件以及apk校验等,容易出