【轉(zhuǎn)】談?wù)勎覍Ψ?wù)熔斷、服務(wù)降級(jí)的理解

本文摘自http://blog.csdn.net/guwei9111986/article/details/51649240

伴隨著微服務(wù)架構(gòu)被宣傳得如火如荼校读,一些概念也被推到了我們面前(管你接受不接受)沼侣,其實(shí)大多數(shù)概念以前就有,但很少被提的這么頻繁(現(xiàn)在好像不提及都不好意思交流了)歉秫。想起有人總結(jié)的一句話蛾洛,微服務(wù)架構(gòu)的特點(diǎn)就是:“一解釋就懂,一問就不知,一討論就吵架”轧膘。

其實(shí)對老外的總結(jié)能力一直特別崇拜钞螟,Kevin Kelly、Martin Fowler谎碍、Werner Vogels……鳞滨,都是著名的“演講家”。正好這段時(shí)間看了些微服務(wù)蟆淀、容器的相關(guān)資料拯啦,也在我們新一代產(chǎn)品中進(jìn)行了部分實(shí)踐,回過頭來熔任,再來談?wù)剬σ恍└拍畹睦斫狻?/p>

今天先來說說“服務(wù)熔斷”和“服務(wù)降級(jí)”褒链。為什么要說這個(gè)呢,因?yàn)槲液荛L時(shí)間里都把這兩個(gè)概念同質(zhì)化了疑苔,不知道這兩個(gè)詞大家怎么理解甫匹,一個(gè)意思o(jì)r有所不同?現(xiàn)在的我是這么來看的:

  1. 在股票市場惦费,熔斷這個(gè)詞大家都不陌生兵迅,是指當(dāng)股指波幅達(dá)到某個(gè)點(diǎn)后,交易所為控制風(fēng)險(xiǎn)采取的暫停交易措施趁餐。相應(yīng)的喷兼,服務(wù)熔斷一般是指軟件系統(tǒng)中,由于某些原因使得服務(wù)出現(xiàn)了過載現(xiàn)象后雷,為防止造成整個(gè)系統(tǒng)故障,從而采用的一種保護(hù)措施吠各,所以很多地方把熔斷亦稱為過載保護(hù)臀突。
  2. 大家都見過女生旅行吧,大號(hào)的旅行箱是必備物贾漏,平常走走近處綽綽有余候学,但一旦出個(gè)遠(yuǎn)門,再大的箱子都白搭了纵散,怎么辦呢梳码?常見的情景就是把物品拿出來分分堆,比了又比伍掀,最后一些非必需品的就忍痛放下了掰茶,等到下次箱子夠用了,再帶上用一用蜜笤。而服務(wù)降級(jí)濒蒋,就是這么回事,整體資源快不夠了,忍痛將某些服務(wù)先關(guān)掉沪伙,待渡過難關(guān)瓮顽,再開啟回來。

所以從上述分析來看围橡,兩者其實(shí)從有些角度看是有一定的類似性的:

  1. 目的很一致暖混,都是從可用性可靠性著想,為防止系統(tǒng)的整體緩慢甚至崩潰翁授,采用的技術(shù)手段儒恋;
  2. 最終表現(xiàn)類似,對于兩者來說黔漂,最終讓用戶體驗(yàn)到的是某些功能暫時(shí)不可達(dá)或不可用诫尽;
  3. 粒度一般都是服務(wù)級(jí)別,當(dāng)然炬守,業(yè)界也有不少更細(xì)粒度的做法牧嫉,比如做到數(shù)據(jù)持久層(允許查詢,不允許增刪改)减途;
  4. 自治性要求很高酣藻,熔斷模式一般都是服務(wù)基于策略的自動(dòng)觸發(fā),降級(jí)雖說可人工干預(yù)鳍置,但在微服務(wù)架構(gòu)下辽剧,完全靠人顯然不可能,開關(guān)預(yù)置税产、配置中心都是必要手段怕轿;

而兩者的區(qū)別也是明顯的:

  1. 觸發(fā)原因不太一樣,服務(wù)熔斷一般是某個(gè)服務(wù)(下游服務(wù))故障引起辟拷,而服務(wù)降級(jí)一般是從整體負(fù)荷考慮撞羽;
  2. 管理目標(biāo)的層次不太一樣,熔斷其實(shí)是一個(gè)框架級(jí)的處理衫冻,每個(gè)微服務(wù)都需要(無層級(jí)之分)诀紊,而降級(jí)一般需要對業(yè)務(wù)有層級(jí)之分(比如降級(jí)一般是從最外圍服務(wù)開始)
  3. 實(shí)現(xiàn)方式不太一樣,這個(gè)區(qū)別后面會(huì)單獨(dú)來說隅俘;

當(dāng)然這只是我個(gè)人對兩者的理解邻奠,外面把兩者歸為完全一致的也不在少數(shù),或者把熔斷機(jī)制理解為應(yīng)對降級(jí)目標(biāo)的一種實(shí)現(xiàn)也說的過去为居,可能“一討論就吵架”也正是這個(gè)原因吧碌宴!概念算是說完了,避免空談颜骤,我再總結(jié)下對常用的實(shí)現(xiàn)方法的理解唧喉。對于這兩個(gè)概念,號(hào)稱支持的框架可不少,Hystrix當(dāng)屬其中的佼佼者八孝。先說說最裸的熔斷器的設(shè)計(jì)思路董朝,下面這張圖大家應(yīng)該不陌生(我只是參考著又畫了畫),簡明扼要的給出了好的熔斷器實(shí)現(xiàn)的三個(gè)狀態(tài)機(jī):

  1. Closed:熔斷器關(guān)閉狀態(tài)干跛,調(diào)用失敗次數(shù)積累子姜,到了閾值(或一定比例)則啟動(dòng)熔斷機(jī)制;
  2. Open:熔斷器打開狀態(tài)楼入,此時(shí)對下游的調(diào)用都內(nèi)部直接返回錯(cuò)誤哥捕,不走網(wǎng)絡(luò),但設(shè)計(jì)了一個(gè)時(shí)鐘選項(xiàng)嘉熊,默認(rèn)的時(shí)鐘達(dá)到了一定時(shí)間(這個(gè)時(shí)間一般設(shè)置成平均故障處理時(shí)間音诈,也就是MTTR)垄开,到了這個(gè)時(shí)間旬陡,進(jìn)入半熔斷狀態(tài)浑塞;
  3. Half-Open:半熔斷狀態(tài),允許定量的服務(wù)請求孕惜,如果調(diào)用都成功(或一定比例)則認(rèn)為恢復(fù)了愧薛,關(guān)閉熔斷器,否則認(rèn)為還沒好衫画,又回到熔斷器打開狀態(tài)毫炉;

那Hystrix,作為Netflix開源框架中的最受喜愛組件之一削罩,是怎么處理依賴隔離瞄勾,實(shí)現(xiàn)熔斷機(jī)制的呢,他的處理遠(yuǎn)比我上面說個(gè)實(shí)現(xiàn)機(jī)制復(fù)雜的多鲸郊,一起來看看核心代碼吧丰榴,我只保留了代碼片段的關(guān)鍵部分:


最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市秆撮,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌换况,老刑警劉巖职辨,帶你破解...
    沈念sama閱讀 217,907評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異戈二,居然都是意外死亡舒裤,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,987評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門觉吭,熙熙樓的掌柜王于貴愁眉苦臉地迎上來腾供,“玉大人,你說我怎么就攤上這事“楸睿” “怎么了节值?”我有些...
    開封第一講書人閱讀 164,298評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長榜聂。 經(jīng)常有香客問我搞疗,道長,這世上最難降的妖魔是什么须肆? 我笑而不...
    開封第一講書人閱讀 58,586評(píng)論 1 293
  • 正文 為了忘掉前任匿乃,我火速辦了婚禮,結(jié)果婚禮上豌汇,老公的妹妹穿的比我還像新娘幢炸。我一直安慰自己,他們只是感情好拒贱,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,633評(píng)論 6 392
  • 文/花漫 我一把揭開白布宛徊。 她就那樣靜靜地躺著,像睡著了一般柜思。 火紅的嫁衣襯著肌膚如雪岩调。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,488評(píng)論 1 302
  • 那天赡盘,我揣著相機(jī)與錄音号枕,去河邊找鬼。 笑死陨享,一個(gè)胖子當(dāng)著我的面吹牛葱淳,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播抛姑,決...
    沈念sama閱讀 40,275評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼赞厕,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了定硝?” 一聲冷哼從身側(cè)響起皿桑,我...
    開封第一講書人閱讀 39,176評(píng)論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎蔬啡,沒想到半個(gè)月后诲侮,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,619評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡箱蟆,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,819評(píng)論 3 336
  • 正文 我和宋清朗相戀三年沟绪,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片空猜。...
    茶點(diǎn)故事閱讀 39,932評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡绽慈,死狀恐怖恨旱,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情坝疼,我是刑警寧澤搜贤,帶...
    沈念sama閱讀 35,655評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站裙士,受9級(jí)特大地震影響入客,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜腿椎,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,265評(píng)論 3 329
  • 文/蒙蒙 一桌硫、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧啃炸,春花似錦铆隘、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,871評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至裹虫,卻和暖如春肿嘲,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背筑公。 一陣腳步聲響...
    開封第一講書人閱讀 32,994評(píng)論 1 269
  • 我被黑心中介騙來泰國打工雳窟, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人匣屡。 一個(gè)月前我還...
    沈念sama閱讀 48,095評(píng)論 3 370
  • 正文 我出身青樓封救,卻偏偏與公主長得像,于是被迫代替她去往敵國和親捣作。 傳聞我的和親對象是個(gè)殘疾皇子誉结,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,884評(píng)論 2 354

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

  • 引言 首先惩坑,之所以談這個(gè)話題呢,是發(fā)現(xiàn)現(xiàn)在很多人對微服務(wù)的設(shè)計(jì)缺乏認(rèn)識(shí)也拜,所以寫一篇掃盲文旭贬。當(dāng)然,考慮到目前大多微服...
    java成功之路閱讀 520評(píng)論 0 4
  • 熔斷限流概述 在基于Spring Cloud的微服務(wù)架構(gòu)體系下扼脐,按照系統(tǒng)功能邊界的不同劃分岸军,原先大而全的系統(tǒng)會(huì)被拆...
    風(fēng)平浪靜如碼閱讀 1,156評(píng)論 0 1
  • 服務(wù)降級(jí) 由于爆炸性的流量沖擊奋刽,對一些服務(wù)進(jìn)行有策略的放棄,以此緩解系統(tǒng)壓力艰赞,保證目前主要業(yè)務(wù)的正常運(yùn)行佣谐。它主要是...
    十丈_紅塵閱讀 8,166評(píng)論 0 34
  • 最近幾年“微服務(wù)”這個(gè)詞可謂是非常的火爆,大有席卷天下的態(tài)勢方妖。幾乎所有公司都在按照自己的理解實(shí)施微服務(wù)狭魂,大公司也在...
    suoga閱讀 957評(píng)論 2 8
  • 我所擁有的,我正在失去党觅。 我所背對的雌澄,我正在面對。 我所悲傷的杯瞻,我正在快樂镐牺。 我所記下的,我正在忘記魁莉。 我覺得時(shí)間...
    鵝卵石媽媽閱讀 264評(píng)論 0 1