hystrix 斷路器相關(guān)配置說明

hystrix.command.default和hystrix.threadpool.default中的default為默認CommandKey

Command Properties
Execution相關(guān)的屬性的配置:
hystrix.command.default.execution.isolation.strategy 隔離策略看彼,默認是Thread, 可選Thread|Semaphore

hystrix.command.default.execution.isolation.thread.timeoutInMilliseconds 命令執(zhí)行超時時間祭陷,默認1000ms

hystrix.command.default.execution.timeout.enabled 執(zhí)行是否啟用超時,默認啟用true
hystrix.command.default.execution.isolation.thread.interruptOnTimeout 發(fā)生超時是是否中斷壤追,默認true
hystrix.command.default.execution.isolation.semaphore.maxConcurrentRequests 最大并發(fā)請求數(shù)宴咧,默認10,該參數(shù)當使用ExecutionIsolationStrategy.SEMAPHORE策略時才有效。如果達到最大并發(fā)請求數(shù)硕蛹,請求會被拒絕。理論上選擇semaphore size的原則和選擇thread size一致硕并,但選用semaphore時每次執(zhí)行的單元要比較小且執(zhí)行速度快(ms級別)妓美,否則的話應(yīng)該用thread。
semaphore應(yīng)該占整個容器(tomcat)的線程池的一小部分鲤孵。
Fallback相關(guān)的屬性
這些參數(shù)可以應(yīng)用于Hystrix的THREAD和SEMAPHORE策略

hystrix.command.default.fallback.isolation.semaphore.maxConcurrentRequests 如果并發(fā)數(shù)達到該設(shè)置值壶栋,請求會被拒絕和拋出異常并且fallback不會被調(diào)用。默認10
hystrix.command.default.fallback.enabled 當執(zhí)行失敗或者請求被拒絕普监,是否會嘗試調(diào)用hystrixCommand.getFallback() 贵试。默認true
Circuit Breaker相關(guān)的屬性
hystrix.command.default.circuitBreaker.enabled 用來跟蹤circuit的健康性,如果未達標則讓request短路凯正。默認true
hystrix.command.default.circuitBreaker.requestVolumeThreshold 一個rolling window內(nèi)最小的請求數(shù)毙玻。如果設(shè)為20,那么當一個rolling window的時間內(nèi)(比如說1個rolling window是10秒)收到19個請求廊散,即使19個請求都失敗桑滩,也不會觸發(fā)circuit break。默認20
hystrix.command.default.circuitBreaker.sleepWindowInMilliseconds 觸發(fā)短路的時間值允睹,當該值設(shè)為5000時运准,則當觸發(fā)circuit break后的5000毫秒內(nèi)都會拒絕request,也就是5000毫秒后才會關(guān)閉circuit缭受。默認5000
hystrix.command.default.circuitBreaker.errorThresholdPercentage錯誤比率閥值胁澳,如果錯誤率>=該值,circuit會被打開米者,并短路所有請求觸發(fā)fallback韭畸。默認50
hystrix.command.default.circuitBreaker.forceOpen 強制打開熔斷器,如果打開這個開關(guān)蔓搞,那么拒絕所有request胰丁,默認false
hystrix.command.default.circuitBreaker.forceClosed 強制關(guān)閉熔斷器 如果這個開關(guān)打開,circuit將一直關(guān)閉且忽略circuitBreaker.errorThresholdPercentage
Metrics相關(guān)參數(shù)
hystrix.command.default.metrics.rollingStats.timeInMilliseconds 設(shè)置統(tǒng)計的時間窗口值的喂分,毫秒值锦庸,circuit break 的打開會根據(jù)1個rolling window的統(tǒng)計來計算。若rolling window被設(shè)為10000毫秒妻顶,則rolling window會被分成n個buckets酸员,每個bucket包含success蜒车,failure,timeout幔嗦,rejection的次數(shù)的統(tǒng)計信息酿愧。默認10000
hystrix.command.default.metrics.rollingStats.numBuckets 設(shè)置一個rolling window被劃分的數(shù)量,若numBuckets=10邀泉,rolling window=10000嬉挡,那么一個bucket的時間即1秒。必須符合rolling window % numberBuckets == 0汇恤。默認10
hystrix.command.default.metrics.rollingPercentile.enabled 執(zhí)行時是否enable指標的計算和跟蹤庞钢,默認true
hystrix.command.default.metrics.rollingPercentile.timeInMilliseconds 設(shè)置rolling percentile window的時間,默認60000
hystrix.command.default.metrics.rollingPercentile.numBuckets 設(shè)置rolling percentile window的numberBuckets因谎。邏輯同上基括。默認6
hystrix.command.default.metrics.rollingPercentile.bucketSize 如果bucket size=100,window=10s财岔,若這10s里有500次執(zhí)行风皿,只有最后100次執(zhí)行會被統(tǒng)計到bucket里去。增加該值會增加內(nèi)存開銷以及排序的開銷匠璧。默認100
hystrix.command.default.metrics.healthSnapshot.intervalInMilliseconds 記錄health 快照(用來統(tǒng)計成功和錯誤綠)的間隔桐款,默認500ms
Request Context 相關(guān)參數(shù)
hystrix.command.default.requestCache.enabled 默認true,需要重載getCacheKey()夷恍,返回null時不緩存
hystrix.command.default.requestLog.enabled 記錄日志到HystrixRequestLog魔眨,默認true

Collapser Properties 相關(guān)參數(shù)
hystrix.collapser.default.maxRequestsInBatch 單次批處理的最大請求數(shù),達到該數(shù)量觸發(fā)批處理酿雪,默認Integer.MAX_VALUE
hystrix.collapser.default.timerDelayInMilliseconds 觸發(fā)批處理的延遲遏暴,也可以為創(chuàng)建批處理的時間+該值,默認10
hystrix.collapser.default.requestCache.enabled 是否對HystrixCollapser.execute() and HystrixCollapser.queue()的cache执虹,默認true

ThreadPool 相關(guān)參數(shù)
線程數(shù)默認值10適用于大部分情況(有時可以設(shè)置得更型鼗印),如果需要設(shè)置得更大袋励,那有個基本得公式可以follow:
requests per second at peak when healthy × 99th percentile latency in seconds + some breathing room
每秒最大支撐的請求數(shù) (99%平均響應(yīng)時間 + 緩存值)
比如:每秒能處理1000個請求,99%的請求響應(yīng)時間是60ms当叭,那么公式是:
(0.060+0.012)

基本得原則時保持線程池盡可能小茬故,他主要是為了釋放壓力,防止資源被阻塞蚁鳖。
當一切都是正常的時候磺芭,線程池一般僅會有1到2個線程激活來提供服務(wù)

hystrix.threadpool.default.coreSize 并發(fā)執(zhí)行的最大線程數(shù),默認10
hystrix.threadpool.default.maxQueueSize BlockingQueue的最大隊列數(shù)醉箕,當設(shè)為-1钾腺,會使用SynchronousQueue徙垫,值為正時使用LinkedBlcokingQueue。該設(shè)置只會在初始化時有效放棒,之后不能修改threadpool的queue size姻报,除非reinitialising thread executor。默認-1间螟。
hystrix.threadpool.default.queueSizeRejectionThreshold 即使maxQueueSize沒有達到吴旋,達到queueSizeRejectionThreshold該值后,請求也會被拒絕厢破。因為maxQueueSize不能被動態(tài)修改荣瑟,這個參數(shù)將允許我們動態(tài)設(shè)置該值。if maxQueueSize == -1摩泪,該字段將不起作用
hystrix.threadpool.default.keepAliveTimeMinutes 如果corePoolSize和maxPoolSize設(shè)成一樣(默認實現(xiàn))該設(shè)置無效笆焰。如果通過plugin(https://github.com/Netflix/Hystrix/wiki/Plugins)使用自定義實現(xiàn),該設(shè)置才有用见坑,默認1.
hystrix.threadpool.default.metrics.rollingStats.timeInMilliseconds 線程池統(tǒng)計指標的時間嚷掠,默認10000
hystrix.threadpool.default.metrics.rollingStats.numBuckets 將rolling window劃分為n個buckets,默認10

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末鳄梅,一起剝皮案震驚了整個濱河市叠国,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌戴尸,老刑警劉巖粟焊,帶你破解...
    沈念sama閱讀 216,402評論 6 499
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異孙蒙,居然都是意外死亡项棠,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,377評論 3 392
  • 文/潘曉璐 我一進店門挎峦,熙熙樓的掌柜王于貴愁眉苦臉地迎上來香追,“玉大人,你說我怎么就攤上這事坦胶⊥傅洌” “怎么了?”我有些...
    開封第一講書人閱讀 162,483評論 0 353
  • 文/不壞的土叔 我叫張陵顿苇,是天一觀的道長峭咒。 經(jīng)常有香客問我,道長纪岁,這世上最難降的妖魔是什么凑队? 我笑而不...
    開封第一講書人閱讀 58,165評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮幔翰,結(jié)果婚禮上漩氨,老公的妹妹穿的比我還像新娘西壮。我一直安慰自己,他們只是感情好叫惊,可當我...
    茶點故事閱讀 67,176評論 6 388
  • 文/花漫 我一把揭開白布款青。 她就那樣靜靜地躺著,像睡著了一般赋访。 火紅的嫁衣襯著肌膚如雪可都。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,146評論 1 297
  • 那天蚓耽,我揣著相機與錄音渠牲,去河邊找鬼。 笑死步悠,一個胖子當著我的面吹牛签杈,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播鼎兽,決...
    沈念sama閱讀 40,032評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼答姥,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了谚咬?” 一聲冷哼從身側(cè)響起鹦付,我...
    開封第一講書人閱讀 38,896評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎择卦,沒想到半個月后敲长,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,311評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡秉继,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,536評論 2 332
  • 正文 我和宋清朗相戀三年祈噪,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片尚辑。...
    茶點故事閱讀 39,696評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡辑鲤,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出杠茬,到底是詐尸還是另有隱情月褥,我是刑警寧澤,帶...
    沈念sama閱讀 35,413評論 5 343
  • 正文 年R本政府宣布瓢喉,位于F島的核電站吓坚,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏灯荧。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,008評論 3 325
  • 文/蒙蒙 一盐杂、第九天 我趴在偏房一處隱蔽的房頂上張望逗载。 院中可真熱鬧哆窿,春花似錦、人聲如沸厉斟。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽擦秽。三九已至码荔,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間感挥,已是汗流浹背缩搅。 一陣腳步聲響...
    開封第一講書人閱讀 32,815評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留触幼,地道東北人硼瓣。 一個月前我還...
    沈念sama閱讀 47,698評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像置谦,于是被迫代替她去往敵國和親堂鲤。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,592評論 2 353