SpringCloudHystrix

在微服務(wù)架構(gòu)中俐载,多個(gè)微服務(wù)互相之間調(diào)用多矮,當(dāng)一個(gè)服務(wù)接口不堪重負(fù)缓淹,出現(xiàn)超時(shí)或宕機(jī)等無法使用的情況時(shí),下游服務(wù)因獲取不到數(shù)據(jù)塔逃,導(dǎo)致服務(wù)不可用讯壶,然后惡性循環(huán)導(dǎo)致整個(gè)服務(wù)體系宕機(jī),形成雪崩效應(yīng)湾盗。此時(shí)熔斷器就充當(dāng)了保險(xiǎn)絲的作用伏蚊,在服務(wù)接口超時(shí)或不可用時(shí),馬上返回一個(gè)錯(cuò)誤信息格粪,讓整個(gè)服務(wù)可以繼續(xù)運(yùn)行丙挽,保護(hù)了整個(gè)服務(wù)體系。否則在高流量應(yīng)用時(shí)候匀借,單個(gè)問題引發(fā)所有資源在短期內(nèi)飽和颜阐,造成服務(wù)之間的延遲,線程及其他資源緊張吓肋,導(dǎo)致系統(tǒng)發(fā)生多個(gè)級聯(lián)故障凳怨,這些都需要對問題以及故障處理,不能因單個(gè)問題導(dǎo)致整個(gè)系統(tǒng)失敗。

Hystrix是一款Netflix開源的熔斷中間件肤舞,是一個(gè)用于處理分布式系統(tǒng)的延遲和容錯(cuò)的開源庫紫新,該框架的主要功能:自我保護(hù)功能。Hystrix具有服務(wù)降級李剖,熔斷芒率,線程池隔離,信號量隔離篙顺,緩存等功能偶芍,基本上能覆蓋到微服務(wù)中調(diào)用依賴服務(wù)會遇到的問題。

Spring Cloud Netflix Hystrix的熔斷機(jī)制主要包括服務(wù)隔離德玫,服務(wù)熔斷服務(wù)回退匪蟀。

服務(wù)隔離又分為線程隔離與進(jìn)程隔離

線程池隔離(默認(rèn))

服務(wù)的調(diào)用者(消費(fèi)者)會從Hystrix線程池中申請一個(gè)線程幫助自己訪問服務(wù),服務(wù)調(diào)用者的線程會阻塞住宰僧,等著線程池中的線程反饋結(jié)果材彪,當(dāng)服務(wù)器宕機(jī),線程池的線程響應(yīng)超時(shí)時(shí)琴儿,該線程池的線程就被全部被申請完段化,此時(shí)就拒絕訪問該服務(wù)器

進(jìn)程隔離

相較于線程隔離更加的容易理解,進(jìn)程隔離就是將一個(gè)系統(tǒng)拆分為多個(gè)子系統(tǒng)以實(shí)現(xiàn)子系統(tǒng)間的物理隔離造成,從進(jìn)程隔離的角度講穗泵,對系統(tǒng)進(jìn)行微服務(wù)建模和拆分就是一種具體的實(shí)現(xiàn)方式,每個(gè)服務(wù)獨(dú)立部署和運(yùn)行谜疤,各個(gè)服務(wù)之間實(shí)現(xiàn)了物理隔離佃延。服務(wù)隔離還包括集群隔離、機(jī)房隔離和讀寫隔離等其他表現(xiàn)形式夷磕。

信號量隔離

每個(gè)前線程去訪問服務(wù)會有標(biāo)記履肃,這個(gè)服務(wù)每訪問一次會加1,服務(wù)訪問成功會減一坐桩,如果這個(gè)值超過10就不讓訪問這個(gè)服務(wù)尺棋,請求就被攔截下來。

降級服務(wù)

當(dāng)需要調(diào)用的微服務(wù)出現(xiàn)問題時(shí)绵跷,默認(rèn)會去調(diào)用一個(gè)本地降級方法膘螟,降級方法會返回錯(cuò)誤信息或者一個(gè)合理的默認(rèn)值,從而繼續(xù)后面的業(yè)務(wù)碾局,線程不會阻塞在哪里荆残。

熔斷器

在微服務(wù)的訪問過程中,如果大量的請求訪問超時(shí)或者失敗净当,則熔斷器就會自動(dòng)打開内斯,如果熔斷器打開之后蕴潦,后續(xù)所有訪問這個(gè)微服務(wù)的請求,會立刻被通知失敗俘闯。熔斷器開啟后潭苞,會每隔一段時(shí)間進(jìn)入半開狀態(tài),半開狀態(tài)下真朗,會釋放一個(gè)服務(wù)嘗試請求資源此疹,如果請求成功,則熔斷器就會 關(guān)閉遮婶,反之又會回到半開的狀態(tài)蝗碎。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市蹭睡,隨后出現(xiàn)的幾起案子衍菱,更是在濱河造成了極大的恐慌赶么,老刑警劉巖肩豁,帶你破解...
    沈念sama閱讀 219,366評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異辫呻,居然都是意外死亡清钥,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,521評論 3 395
  • 文/潘曉璐 我一進(jìn)店門放闺,熙熙樓的掌柜王于貴愁眉苦臉地迎上來祟昭,“玉大人,你說我怎么就攤上這事怖侦〈畚颍” “怎么了?”我有些...
    開封第一講書人閱讀 165,689評論 0 356
  • 文/不壞的土叔 我叫張陵匾寝,是天一觀的道長搬葬。 經(jīng)常有香客問我,道長艳悔,這世上最難降的妖魔是什么急凰? 我笑而不...
    開封第一講書人閱讀 58,925評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮猜年,結(jié)果婚禮上抡锈,老公的妹妹穿的比我還像新娘。我一直安慰自己乔外,他們只是感情好床三,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,942評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著杨幼,像睡著了一般勿璃。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,727評論 1 305
  • 那天补疑,我揣著相機(jī)與錄音歧沪,去河邊找鬼。 笑死莲组,一個(gè)胖子當(dāng)著我的面吹牛诊胞,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播锹杈,決...
    沈念sama閱讀 40,447評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼撵孤,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了竭望?” 一聲冷哼從身側(cè)響起邪码,我...
    開封第一講書人閱讀 39,349評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎咬清,沒想到半個(gè)月后闭专,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,820評論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡旧烧,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,990評論 3 337
  • 正文 我和宋清朗相戀三年影钉,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片掘剪。...
    茶點(diǎn)故事閱讀 40,127評論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡平委,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出夺谁,到底是詐尸還是另有隱情廉赔,我是刑警寧澤,帶...
    沈念sama閱讀 35,812評論 5 346
  • 正文 年R本政府宣布匾鸥,位于F島的核電站蜡塌,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏扫腺。R本人自食惡果不足惜岗照,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,471評論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望笆环。 院中可真熱鬧攒至,春花似錦、人聲如沸躁劣。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,017評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽账忘。三九已至志膀,卻和暖如春熙宇,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背溉浙。 一陣腳步聲響...
    開封第一講書人閱讀 33,142評論 1 272
  • 我被黑心中介騙來泰國打工烫止, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人戳稽。 一個(gè)月前我還...
    沈念sama閱讀 48,388評論 3 373
  • 正文 我出身青樓馆蠕,卻偏偏與公主長得像,于是被迫代替她去往敵國和親惊奇。 傳聞我的和親對象是個(gè)殘疾皇子互躬,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,066評論 2 355

推薦閱讀更多精彩內(nèi)容