真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Hystrix屬性配置大全-創(chuàng)新互聯(lián)

  1. 概述
    本文對Hystrix的配置參數(shù)的覆蓋優(yōu)先級,可配置參數(shù)的種類、配置項進行詳細的介紹。

Hystrix可以配置屬性的有以下類型:

10年積累的成都網(wǎng)站建設、成都做網(wǎng)站經(jīng)驗,可以快速應對客戶對網(wǎng)站的新想法和需求。提供各種問題對應的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡服務。我雖然不認識你,你也不認識我。但先做網(wǎng)站后付款的網(wǎng)站建設流程,更有南沙免費網(wǎng)站建設讓你可以放心的選擇與我們合作。

Execution:控制HystrixCommand.run() 的如何執(zhí)行
Fallback: 控制HystrixCommand.getFallback() 如何執(zhí)行
Circuit Breaker: 控制斷路器的行為
Metrics: 捕獲和HystrixCommand 和 HystrixObservableCommand 執(zhí)行信息相關(guān)的配置屬性
Request Context:設置請求上下文的屬性
Collapser Properties:設置請求合并的屬性
Thread Pool Properties:設置線程池的屬性

  1. Hystrix參數(shù)的覆蓋優(yōu)先級
    每個Hystrix參數(shù)都有4個地方可以配置,優(yōu)先級從低到高如下,如果每個地方都配置相同的屬性,則優(yōu)先級高的值會覆蓋優(yōu)先級低的值

1 內(nèi)置全局默認值:寫死在代碼里的值
2 動態(tài)全局默認屬性:通過屬性文件配置全局的值
3 內(nèi)置實例默認值:寫死在代碼里的實例的值
4 動態(tài)配置實例屬性:通過屬性文件配置特定實例的值
3 Hystrix配置屬性詳解
Hystrix可以配置屬性的有以下類型:

Execution:控制HystrixCommand.run() 的如何執(zhí)行
Fallback: 控制HystrixCommand.getFallback() 如何執(zhí)行
Circuit Breaker: 控制斷路器的行為
Metrics: 捕獲和HystrixCommand 和 HystrixObservableCommand 執(zhí)行信息相關(guān)的配置屬性
Request Context:設置請求上下文的屬性
Collapser Properties:設置請求合并的屬性
Thread Pool Properties:設置線程池的屬性
3.1. Execution
以下屬性控制HystrixCommand.run() 的如何執(zhí)行

  1. execution.isolation.strategy
    表示HystrixCommand.run()的執(zhí)行時的隔離策略,有以下兩種策略

1 THREAD: 在單獨的線程上執(zhí)行,并發(fā)請求受線程池中的線程數(shù)限制
2 SEMAPHORE: 在調(diào)用線程上執(zhí)行,并發(fā)請求量受信號量計數(shù)限制
在默認情況下,推薦HystrixCommands 使用 thread 隔離策略,HystrixObservableCommand 使用 semaphore 隔離策略。
只有在高并發(fā)(單個實例每秒達到幾百個調(diào)用)的調(diào)用時,才需要修改HystrixCommands 的隔離策略為semaphore 。semaphore 隔離策略通常只用于非網(wǎng)絡調(diào)用

默認值:THREAD,

// 設置所有實例的默認值
hystrix.command.default.execution.isolation.strategy=..
// 設置實例HystrixCommandKey的此屬性值
hystrix.command.HystrixCommandKey.execution.isolation.strategy=...

  1. execution.isolation.thread.timeoutInMilliseconds
    設置調(diào)用者執(zhí)行的超時時間(單位毫秒)

默認值:1000

// 設置所有實例的默認值
hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds=...
// 設置實例HystrixCommandKey的此屬性值
hystrix.command.HystrixCommandKey.execution.isolation.thread.timeoutInMilliseconds=...

  1. execution.timeout.enabled
    表示是否開啟超時設置。

默認值:true

// 設置所有實例的默認值
hystrix.command.default.execution.timeout.enabled=...
// 設置實例HystrixCommandKey的此屬性值
hystrix.command.HystrixCommandKey.execution.timeout.enabled=...

  1. execution.isolation.thread.interruptOnTimeout
    表示設置是否在執(zhí)行超時時,中斷HystrixCommand.run() 的執(zhí)行

默認值:true

// 設置所有實例的默認值
hystrix.command.default.execution.isolation.thread.interruptOnTimeout=...
// 設置實例HystrixCommandKey的此屬性值
hystrix.command.HystrixCommandKey.execution.isolation.thread.interruptOnTimeout=...

  1. execution.isolation.thread.interruptOnCancel
    表示設置是否在取消任務執(zhí)行時,中斷HystrixCommand.run() 的執(zhí)行

默認值:false

// 設置所有實例的默認值
hystrix.command.default.execution.isolation.thread.interruptOnCancel=...
// 設置實例HystrixCommandKey的此屬性值
hystrix.command.HystrixCommandKey.execution.isolation.thread.interruptOnCancel

  1. execution.isolation.semaphore.maxConcurrentRequests

當HystrixCommand.run()使用SEMAPHORE的隔離策略時,設置大的并發(fā)量

默認值:10

// 設置所有實例的默認值
hystrix.command.default.execution.isolation.semaphore.maxConcurrentRequests=...

// 設置實例HystrixCommandKey的此屬性值
hystrix.command.HystrixCommandKey.execution.isolation.semaphore.maxConcurrentRequests=...

3.2. Fallback
以下屬性控制HystrixCommand.getFallback() 如何執(zhí)行。這些屬性對隔離策略THREAD 和SEMAPHORE都起作用.

  1. fallback.isolation.semaphore.maxConcurrentRequests
    此屬性設置從調(diào)用線程允許HystrixCommand.getFallback()方法允許的大并發(fā)請求數(shù)
    如果達到大的并發(fā)量,則接下來的請求會被拒絕并且拋出異常.

默認值:10

// 設置所有實例的默認值
hystrix.command.default.fallback.isolation.semaphore.maxConcurrentRequests=...
// 設置實例HystrixCommandKey的此屬性值
hystrix.command.HystrixCommandKey.fallback.isolation.semaphore.maxConcurrentRequests=...
1
2
3
4

  1. fallback.enabled
    是否開啟fallback功能

默認值:true

// 設置所有實例的默認值
hystrix.command.default.fallback.enabled=...
// 設置實例HystrixCommandKey的此屬性值
hystrix.command.HystrixCommandKey.fallback.enabled=...

3.3. Circuit Breaker
控制斷路器的行為

1. circuitBreaker.enabled
是否開啟斷路器功能

默認值:true

// 設置所有實例的默認值
hystrix.command.default.circuitBreaker.enabled=...
// 設置實例HystrixCommandKey的此屬性值
hystrix.command.HystrixCommandKey.circuitBreaker.enabled=...

  1. circuitBreaker.requestVolumeThreshold

該屬性設置滾動窗口中將使斷路器跳閘的最小請求數(shù)量

如果此屬性值為20,則在窗口時間內(nèi)(如10s內(nèi)),如果只收到19個請求且都失敗了,則斷路器也不會開啟。

默認值:20

// 設置所有實例的默認值
hystrix.command.default.circuitBreaker.requestVolumeThreshold=...

// 設置實例HystrixCommandKey的此屬性值
hystrix.command.HystrixCommandKey.circuitBreaker.requestVolumeThreshold=...
1
2
3
4
5
3. circuitBreaker.sleepWindowInMilliseconds
斷路器跳閘后,在此值的時間的內(nèi),hystrix會拒絕新的請求,只有過了這個時間斷路器才會打開閘門

默認值:5000

// 設置所有實例的默認值
hystrix.command.default.circuitBreaker.sleepWindowInMilliseconds=...
// 設置實例HystrixCommandKey的此屬性值
hystrix.command.HystrixCommandKey.circuitBreaker.sleepWindowInMilliseconds=...

  1. circuitBreaker.errorThresholdPercentage

設置失敗百分比的閾值。如果失敗比率超過這個值,則斷路器跳閘并且進入fallback邏輯

默認值:50

// 設置所有實例的默認值
hystrix.command.default.circuitBreaker=...
// 設置實例HystrixCommandKey的此屬性值
hystrix.command.HystrixCommandKey.circuitBreaker.errorThresholdPercentage=...

  1. circuitBreaker.forceOpen
    如果設置true,則強制使斷路器跳閘,則會拒絕所有的請求.此值會覆蓋circuitBreaker.forceClosed的值

默認值:false

// 設置所有實例的默認值
hystrix.command.default.circuitBreaker.forceOpen=...
// 設置實例HystrixCommandKey的此屬性值
hystrix.command.HystrixCommandKey.circuitBreaker.forceOpen=...

  1. circuitBreaker.forceClosed
    如果設置true,則強制使斷路器進行關(guān)閉狀態(tài),此時會允許執(zhí)行所有請求,無論是否失敗的次數(shù)達到circuitBreaker.errorThresholdPercentage值

默認值:false

// 設置所有實例的默認值
hystrix.command.default.circuitBreaker.forceClosed=...
// 設置實例HystrixCommandKey的此屬性值
hystrix.command.HystrixCommandKey.circuitBreaker.forceClosed=...

3.4. Metrics
捕獲和HystrixCommand 和 HystrixObservableCommand 執(zhí)行信息相關(guān)的配置屬性

  1. metrics.rollingStats.timeInMilliseconds
    設置統(tǒng)計滾動窗口的時間長度

如果此值為10s,將窗口分成10個桶,每個桶表示1s時間,則統(tǒng)計信息如下圖:

默認值: 10000

// 設置所有實例的默認值
hystrix.command.default.metrics.rollingStats.timeInMilliseconds=10000

// 設置實例HystrixCommandKey的此屬性值
hystrix.command.HystrixCommandKey.metrics.rollingStats.timeInMilliseconds=10000

  1. metrics.rollingStats.numBuckets
    設置統(tǒng)計滾動窗口的桶數(shù)量,

注意:以下配置必須成立,否則會拋出異常。

metrics.rollingStats.timeInMilliseconds % metrics.rollingStats.numBuckets == 0
1
如:10000/10、10000/20是正確的配置,但是10000/7錯誤的

在高并發(fā)的環(huán)境里,每個桶的時間長度建議大于100ms

默認值:10

// 設置所有實例的默認值
hystrix.command.default.metrics.rollingStats.numBuckets=...
// 設置實例HystrixCommandKey的此屬性值
hystrix.command.HystrixCommandKey.metrics.rollingStats.numBuckets=...

  1. metrics.rollingPercentile.enabled

設置執(zhí)行延遲是否被跟蹤,并且被計算在失敗百分比中。如果設置為false,則所有的統(tǒng)計數(shù)據(jù)返回-1

默認值: true

// 設置所有實例的默認值
hystrix.command.default.metrics.rollingPercentile.enabled=...

// 設置實例HystrixCommandKey的此屬性值
hystrix.command.HystrixCommandKey.metrics.rollingPercentile.enabled=...

  1. metrics.rollingPercentile.timeInMilliseconds

此屬性設置統(tǒng)計滾動百分比窗口的持續(xù)時間

默認值:60000

// 設置所有實例的默認值
hystrix.command.default.metrics.rollingPercentile.timeInMilliseconds=...
// 設置實例HystrixCommandKey的此屬性值
hystrix.command.HystrixCommandKey.metrics.rollingPercentile.timeInMilliseconds=...

  1. metrics.rollingPercentile.numBuckets
    設置統(tǒng)計滾動百分比窗口的桶數(shù)量

注意:以下配置必須成立,否則會拋出異常。

metrics.rollingPercentile.timeInMilliseconds % metrics.rollingPercentile.numBuckets == 0
1
如: 60000/6、60000/60是正確的配置,但是10000/7錯誤的

在高并發(fā)的環(huán)境里,每個桶的時間長度建議大于1000ms

默認值:6

// 設置所有實例的默認值
hystrix.command.default.metrics.rollingPercentile.numBuckets=...

// 設置實例HystrixCommandKey的此屬性值
hystrix.command.HystrixCommandKey.metrics.rollingPercentile.numBuckets=...

  1. metrics.rollingPercentile.bucketSize
    此屬性設置每個桶保存的執(zhí)行時間的大值。如果桶數(shù)量是100,統(tǒng)計窗口為10s,如果這10s里有500次執(zhí)行,只有最后100次執(zhí)行會被統(tǒng)計到bucket里去

默認值:100

// 設置所有實例的默認值
hystrix.command.default.metrics.rollingPercentile.bucketSize=...
// 設置實例HystrixCommandKey的此屬性值
hystrix.command.HystrixCommandKey.metrics.rollingPercentile.bucketSize=...

  1. metrics.healthSnapshot.intervalInMilliseconds

采樣時間間隔

默認值:500

// 設置所有實例的默認值
hystrix.command.default.metrics.healthSnapshot.intervalInMilliseconds=...
// 設置實例HystrixCommandKey的此屬性值
hystrix.command.HystrixCommandKey.metrics.healthSnapshot.intervalInMilliseconds=...

3.5. Request Context
此屬性控制HystrixCommand使用到的Hystrix的上下文

  1. requestCache.enabled
    是否開啟請求緩存功能

默認值:true

// 設置所有實例的默認值
hystrix.command.default.requestCache.enabled=...

// 設置實例HystrixCommandKey的此屬性值
hystrix.command.HystrixCommandKey.requestCache.enabled=...

  1. requestLog.enabled
    表示是否開啟日志,打印執(zhí)行HystrixCommand的情況和事件

默認值:true

// 設置所有實例的默認值
hystrix.command.default.requestLog.enabled=...
// 設置實例HystrixCommandKey的此屬性值
hystrix.command.HystrixCommandKey.requestLog.enabled=...

3.6. Collapser Properties###
設置請求合并的屬性

  1. maxRequestsInBatch
    設置同時批量執(zhí)行的請求的大數(shù)量

默認值:Integer.MAX_VALUE

// 設置所有實例的默認值
hystrix.collapser.default.maxRequestsInBatch=...
// 設置實例HystrixCommandKey的此屬性值
hystrix.collapser.HystrixCollapserKey.maxRequestsInBatch=...

  1. timerDelayInMilliseconds
    批量執(zhí)行創(chuàng)建多久之后,再觸發(fā)真正的請求

默認值:10

// 設置所有實例的默認值
hystrix.collapser.default.timerDelayInMilliseconds=...
// 設置實例HystrixCommandKey的此屬性值
hystrix.collapser.HystrixCollapserKey.timerDelayInMilliseconds=...

  1. requestCache.enabled
    是否對HystrixCollapser.execute() 和 HystrixCollapser.queue()開啟請求緩存

默認值:true

// 設置所有實例的默認值
hystrix.collapser.default.requestCache.enabled=...
// 設置實例HystrixCommandKey的此屬性值
hystrix.collapser.HystrixCollapserKey.requestCache.enabled=...

3.7. Thread Pool Properties
設置Hystrix Commands的線程池行為,大部分情況線程數(shù)量是10。

線程池數(shù)量的計算公式如下:

最高峰時每秒的請求數(shù)量 × 99%命令執(zhí)行時間 + 喘息空間
1
設置線程池數(shù)量的主要原則是保持線程池越小越好,因為它是減輕負載并防止資源在延遲發(fā)生時被阻塞的主要工具

  1. coreSize
    設置線程池的core的大小

默認值:10

// 設置所有實例的默認值
hystrix.threadpool.default.coreSize=...
// 設置實例HystrixCommandKey的此屬性值
hystrix.threadpool.HystrixThreadPoolKey.coreSize=...

  1. maximumSize
    設置大的線程池的大小,只有設置allowMaximumSizeToDivergeFromCoreSize時,此值才起作用

默認值:10

// 設置所有實例的默認值
hystrix.threadpool.default.maximumSize=...
// 設置實例HystrixCommandKey的此屬性值
hystrix.threadpool.HystrixThreadPoolKey.maximumSize=...
1
2
3
4

  1. maxQueueSize
    設置大的BlockingQueue隊列的值。如果設置-1,則使用SynchronousQueue隊列,如果設置正數(shù),則使用LinkedBlockingQueue隊列

默認值:-1

// 設置所有實例的默認值
hystrix.threadpool.default.maxQueueSize=...
// 設置實例HystrixCommandKey的此屬性值
hystrix.threadpool.HystrixThreadPoolKey.maxQueueSize=...

  1. queueSizeRejectionThreshold
    因為maxQueueSize值不能被動態(tài)修改,所有通過設置此值可以實現(xiàn)動態(tài)修改等待隊列長度。即等待的隊列的數(shù)量大于queueSizeRejectionThreshold時(但是沒有達到maxQueueSize值),則開始拒絕后續(xù)的請求進入隊列。

如果設置-1,則屬性不啟作用

默認值:5

// 設置所有實例的默認值
hystrix.threadpool.default.queueSizeRejectionThreshold=...
// 設置實例HystrixCommandKey的此屬性值
hystrix.threadpool.HystrixThreadPoolKey.queueSizeRejectionThreshold=...

  1. keepAliveTimeMinutes
    設置線程多久沒有服務后,需要釋放(maximumSize-coreSize )個線程

默認值:1

// 設置所有實例的默認值
hystrix.threadpool.default.keepAliveTimeMinutes=...
// 設置實例HystrixCommandKey的此屬性值
hystrix.threadpool.HystrixThreadPoolKey.keepAliveTimeMinutes=...

6. allowMaximumSizeToDivergeFromCoreSize
設置allowMaximumSizeToDivergeFromCoreSize值為true時,maximumSize才有作用
默認值:false

// 設置所有實例的默認值
hystrix.threadpool.default.allowMaximumSizeToDivergeFromCoreSize=....
// 設置實例HystrixCommandKey的此屬性值
hystrix.threadpool.HystrixThreadPoolKey.allowMaximumSizeToDivergeFromCoreSize=...

  1. metrics.rollingStats.timeInMilliseconds
    設置滾動窗口的時間

默認值:10000

// 設置所有實例的默認值
hystrix.threadpool.default.metrics.rollingStats.timeInMilliseconds=...
// 設置實例HystrixCommandKey的此屬性值
hystrix.threadpool.HystrixThreadPoolKey.metrics.rollingStats.timeInMilliseconds=...

  1. metrics.rollingStats.numBuckets
    設置滾動靜態(tài)窗口分成的桶的數(shù)量

配置的值必須滿足如下條件:

metrics.rollingStats.timeInMilliseconds % metrics.rollingStats.numBuckets == 0
1
默認值:10
建議每個桶的時間長度大于100ms

// 設置所有實例的默認值
hystrix.threadpool.default.metrics.rollingStats.numBuckets=...
// 設置實例HystrixCommandKey的此屬性值
hystrix.threadpool.HystrixThreadPoolProperties.metrics.rollingStats.numBuckets=...

另外有需要云服務器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。


文章題目:Hystrix屬性配置大全-創(chuàng)新互聯(lián)
文章轉(zhuǎn)載:http://weahome.cn/article/edgjo.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部