淺談服務(wù)雪崩

服務(wù)雪崩的過(guò)程

服務(wù)關(guān)系

上面是一組簡(jiǎn)單的服務(wù)依賴關(guān)系A(chǔ),B服務(wù)同時(shí)依賴于基礎(chǔ)服務(wù)C瘩绒,基礎(chǔ)服務(wù)C又調(diào)用了服務(wù)D

D響應(yīng)變慢

服務(wù)D是一個(gè)輔助類型服務(wù)列牺,整個(gè)業(yè)務(wù)不依賴于D服務(wù),某天D服務(wù)突然響應(yīng)時(shí)間變長(zhǎng)划纽,導(dǎo)致了核心服務(wù)C響應(yīng)時(shí)間變長(zhǎng)脆侮,其上請(qǐng)求越積越多,C服務(wù)也出現(xiàn)了響應(yīng)變慢的情況勇劣,由于A靖避,B強(qiáng)依賴于服務(wù)C,故而一個(gè)無(wú)關(guān)緊要的服務(wù)卻影響了整個(gè)系統(tǒng)的可用比默。


影響了整個(gè)系統(tǒng)

雪崩是系統(tǒng)中的蝴蝶效應(yīng)導(dǎo)致其發(fā)生的原因多種多樣幻捏,有不合理的容量設(shè)計(jì),或者是高并發(fā)下某一個(gè)方法響應(yīng)變慢命咐,亦或是某臺(tái)機(jī)器的資源耗盡篡九。從源頭上我們無(wú)法完全杜絕雪崩源頭的發(fā)生,但是雪崩的根本原因來(lái)源于服務(wù)之間的強(qiáng)依賴醋奠,所以我們可以提前評(píng)估榛臼,做好熔斷,隔離窜司,限流沛善。


熔斷

熔斷器

說(shuō)到熔斷器,java技術(shù)棧的同學(xué)第一時(shí)間會(huì)想到Hystrix塞祈。下面我們一起來(lái)看下熔斷器的實(shí)現(xiàn)原理

狀態(tài)轉(zhuǎn)移

熔斷器實(shí)際上是一個(gè)簡(jiǎn)單的有限狀態(tài)機(jī)(Finite State Machine)

1.請(qǐng)求錯(cuò)誤率達(dá)到某一閾值金刁,熔斷器全開(kāi),產(chǎn)生熔斷(熔斷期間會(huì)對(duì)所有請(qǐng)求采用降級(jí)處理)

2.到熔斷時(shí)間窗口之后议薪,熔斷器會(huì)進(jìn)入半開(kāi)狀態(tài)尤蛮,此時(shí)hystrix會(huì)放過(guò)1個(gè)試驗(yàn)性請(qǐng)求

3.如果該試驗(yàn)性請(qǐng)求成功,熔斷器進(jìn)入關(guān)閉狀態(tài)

4.如果該試驗(yàn)性請(qǐng)求失敗笙蒙,熔斷器重新進(jìn)入全開(kāi)狀態(tài)

以下摘自hystrix官方文檔

1.Assuming the volume across a circuit meets a certain threshold (HystrixCommandProperties.circuitBreakerRequestVolumeThreshold())...

2.And assuming that the error percentage exceeds the threshold error percentage (HystrixCommandProperties.circuitBreakerErrorThresholdPercentage())...

3.Then the circuit-breaker transitions from?CLOSED?to?OPEN.

4.While it is open, it short-circuits all requests made against that circuit-breaker.

5.After some amount of time (HystrixCommandProperties.circuitBreakerSleepWindowInMilliseconds()), the next single request is let through (this is the?HALF-OPEN?state). If the request fails, the circuit-breaker returns to the?OPEN?state for the duration of the sleep window. If the request succeeds, the circuit-breaker transitions to?CLOSED?and the logic in?1.?takes over again.

指標(biāo)Metric

hystrix內(nèi)部的統(tǒng)計(jì)指標(biāo)是基于觀察者模式的抵屿,只不過(guò)事件的統(tǒng)計(jì)方式1.4.x與1.5.0王后的版本有些許不同。

1.4.x版本實(shí)現(xiàn)

摘自?https://github.com/Netflix/Hystrix/wiki/How-it-Works#circuit-breaker


采用滑動(dòng)窗口+滾筒的機(jī)制進(jìn)行指標(biāo)統(tǒng)計(jì)捅位,一個(gè)完整的時(shí)間窗口被劃分為多個(gè)bucket轧葛,圖中的一個(gè)bucket統(tǒng)計(jì)的是1s內(nèi)的計(jì)數(shù)指標(biāo)搂抒,分別是success,failure尿扯,timeout求晶,rejection,熔斷器評(píng)判標(biāo)準(zhǔn)是整個(gè)時(shí)間窗口的成功失敗比衷笋。

1.5.0以后版本

利用了hystirx大量引入了rxjava? api芳杏,其保留了滾筒機(jī)制,只不過(guò)bucket內(nèi)部的時(shí)間段指標(biāo)統(tǒng)計(jì)利用了Observable.window?函數(shù)進(jìn)行時(shí)間段內(nèi)聚合統(tǒng)計(jì)辟宗。

rxjava window函數(shù)


Observable.window操作分為2個(gè)維度爵赵,分別是bucket級(jí)別和window級(jí)別。

bucket級(jí)別的數(shù)據(jù)聚合是在BucketedCounterStream.java類中執(zhí)行泊脐,其功能是將服務(wù)調(diào)用級(jí)別的輸入數(shù)據(jù)流 inputEventStream 以 bucketSizeInMs 毫秒為一個(gè)桶進(jìn)行了匯總空幻,匯總的結(jié)果輸入到桶級(jí)別數(shù)據(jù)流 bucketedStream。

BucketedCounterStream.java

window級(jí)別的數(shù)據(jù)在BucketedRollingCounterStream.java類中進(jìn)行聚合容客,numBuckets定義了window的大小秕铛,reduceWindowToSummary為窗口求和操作。

BucketedRollingCounterStream.java

使用rxjava給hystrix帶來(lái)了下面幾點(diǎn)好處

無(wú)需再次編碼

比如window中的"滾筒"操作直接可以利用rxjava的window函數(shù)并且在后臺(tái)線程中運(yùn)行缩挑,無(wú)需自己再編碼實(shí)現(xiàn)

減少了線程同步

比如每條command emit的數(shù)據(jù)會(huì)發(fā)射到?thread-local級(jí)別的rx.Subject但两,無(wú)需再進(jìn)行同步操作,


資源隔離

太空科幻題材電影永遠(yuǎn)是好萊塢最炙手可熱的主題供置,而一部電影是否能夠扣人心弦逃跑的橋段自然不能少谨湘,尤其在狹小的空間站中∈堪溃《地心引力》中的女主逃離著火的國(guó)際空間站悲关,《異行》中飛船上的伙計(jì)們逃離異行的追殺,《星際穿越》中庫(kù)珀逃離旋轉(zhuǎn)的空間站娄柳,似乎大家面對(duì)危險(xiǎn)的第一反應(yīng)就是“關(guān)上艙門(mén)”寓辱,把危險(xiǎn)隔離在外。

防水倉(cāng)

實(shí)際上船艙分開(kāi)設(shè)計(jì)本身就是一種隔離的思想赤拒,一個(gè)防水倉(cāng)進(jìn)水不會(huì)導(dǎo)致整艘輪船沉沒(méi)秫筏。如果把我們整個(gè)系統(tǒng)比作海上漂浮的一艘輪船,那么我們系統(tǒng)的各個(gè)服務(wù)就好比輪船上的各個(gè)密封艙挎挖,服務(wù)A如果強(qiáng)依賴于服務(wù)B那么他們就在一個(gè)艙里这敬。

應(yīng)用級(jí)別隔離

常見(jiàn)的應(yīng)用界別隔離手段有線程池隔離,信號(hào)量隔離蕉朵,連接池隔離崔涂,hystrix實(shí)現(xiàn)了前2種,其各自優(yōu)缺點(diǎn)如下

線程池隔離與信號(hào)量隔離

硬件資源級(jí)別隔離

說(shuō)到硬件級(jí)別的隔離就想到了近些年來(lái)大熱的docker

docker

docker的sandbox特性可以讓我們的應(yīng)用如圖中的集裝箱一個(gè)個(gè)彼此分開(kāi)始衅,單個(gè)集裝箱的損壞不會(huì)影響到整個(gè)服務(wù)器環(huán)境冷蚂。docker為我們提供了以下幾種硬件隔離方式缭保。

docker中計(jì)算機(jī)資源隔離

docker 通過(guò) cgroup 來(lái)控制容器使用的資源配額,包括 CPU蝙茶、內(nèi)存艺骂、磁盤(pán)IO三大方面

cgroup 是 Control Groups 的縮寫(xiě),是 Linux 內(nèi)核提供的一種可以限制隆夯、記錄钳恕、隔離進(jìn)程組所使用的物理資源(如 cpu、memory蹄衷、磁盤(pán)IO等等) 的機(jī)制忧额,被 LXC、docker 等很多項(xiàng)目用于實(shí)現(xiàn)進(jìn)程資源控制宦芦。

CPU

CPU份額控制

通過(guò)-c或者–cpu-shares參數(shù)宙址,在創(chuàng)建容器時(shí)指定容器所使用的 CPU 份額值

CPU周期控制

-cpu-period轴脐、--cpu-quota兩個(gè)參數(shù)控制容器可以分配到的 CPU 時(shí)鐘周期

CPU核心數(shù)控制

使用–cpuset-cpu s和–cpuset-mems參數(shù)可以控制容器運(yùn)行限定使用哪些 CPU 內(nèi)核和內(nèi)存節(jié)點(diǎn)

內(nèi)存

-m 或 --memory:設(shè)置內(nèi)存的使用限額调卑,例如 100M, 2G。

--memory-swap:設(shè)置 內(nèi)存+swap 的使用限額大咱。

IO

block IO 權(quán)重

--blkio-weight參數(shù)可以改變?nèi)萜?block IO 的優(yōu)先級(jí)

限制 bps 和 iops

bps 是 byte per second恬涧,每秒讀寫(xiě)的數(shù)據(jù)量。iops 是 io per second碴巾,每秒 IO 的次數(shù)溯捆。

--device-read-bps,限制讀某個(gè)設(shè)備的 bps厦瓢。

--device-write-bps提揍,限制寫(xiě)某個(gè)設(shè)備的 bps。

--device-read-iops煮仇,限制讀某個(gè)設(shè)備的 iops劳跃。

--device-write-iops,限制寫(xiě)某個(gè)設(shè)備的 iops浙垫。

docker中內(nèi)核資源隔離

Linux Namespace 是 Linux 提供的一種內(nèi)核級(jí)別環(huán)境隔離的方法

docker網(wǎng)絡(luò)隔離

none 網(wǎng)絡(luò)

host 網(wǎng)絡(luò)

bridge 網(wǎng)絡(luò)

User-defined 網(wǎng)絡(luò)






資料參考:

http://reactivex.io/documentation/operators.html

https://segmentfault.com/a/1190000005988895

https://github.com/Netflix/Hystrix/wiki

https://blog.csdn.net/hustspy1990/article/details/77978329

http://blog.51cto.com/wzlinux/2046566

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末刨仑,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子夹姥,更是在濱河造成了極大的恐慌杉武,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,509評(píng)論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件辙售,死亡現(xiàn)場(chǎng)離奇詭異轻抱,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)旦部,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,806評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門(mén)祈搜,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)封拧,“玉大人,你說(shuō)我怎么就攤上這事夭问≡笪鳎” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 163,875評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵缰趋,是天一觀的道長(zhǎng)捧杉。 經(jīng)常有香客問(wèn)我,道長(zhǎng)秘血,這世上最難降的妖魔是什么味抖? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,441評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮灰粮,結(jié)果婚禮上仔涩,老公的妹妹穿的比我還像新娘。我一直安慰自己粘舟,他們只是感情好熔脂,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,488評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著柑肴,像睡著了一般霞揉。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上晰骑,一...
    開(kāi)封第一講書(shū)人閱讀 51,365評(píng)論 1 302
  • 那天适秩,我揣著相機(jī)與錄音,去河邊找鬼硕舆。 笑死秽荞,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的抚官。 我是一名探鬼主播扬跋,決...
    沈念sama閱讀 40,190評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼耗式!你這毒婦竟也來(lái)了胁住?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,062評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤刊咳,失蹤者是張志新(化名)和其女友劉穎彪见,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體娱挨,經(jīng)...
    沈念sama閱讀 45,500評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡余指,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,706評(píng)論 3 335
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片酵镜。...
    茶點(diǎn)故事閱讀 39,834評(píng)論 1 347
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡碉碉,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出淮韭,到底是詐尸還是另有隱情垢粮,我是刑警寧澤,帶...
    沈念sama閱讀 35,559評(píng)論 5 345
  • 正文 年R本政府宣布靠粪,位于F島的核電站蜡吧,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏占键。R本人自食惡果不足惜昔善,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,167評(píng)論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望畔乙。 院中可真熱鬧君仆,春花似錦、人聲如沸牲距。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,779評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)嗅虏。三九已至洛姑,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間皮服,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,912評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工参咙, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留龄广,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,958評(píng)論 2 370
  • 正文 我出身青樓蕴侧,卻偏偏與公主長(zhǎng)得像择同,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子净宵,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,779評(píng)論 2 354

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

  • 1敲才、springCloudNetFlix 包含內(nèi)容 提供的模式包括服務(wù)發(fā)現(xiàn)(Eureka) 斷路器(Hystrix...
    卡戎li閱讀 902評(píng)論 0 1
  • (git上的源碼:https://gitee.com/rain7564/spring_microservices_...
    sprainkle閱讀 9,350評(píng)論 13 33
  • 關(guān)于Mongodb的全面總結(jié) MongoDB的內(nèi)部構(gòu)造《MongoDB The Definitive Guide》...
    中v中閱讀 31,930評(píng)論 2 89
  • 專業(yè)考題類型管理運(yùn)行工作負(fù)責(zé)人一般作業(yè)考題內(nèi)容選項(xiàng)A選項(xiàng)B選項(xiàng)C選項(xiàng)D選項(xiàng)E選項(xiàng)F正確答案 變電單選GYSZ本規(guī)程...
    小白兔去釣魚(yú)閱讀 8,988評(píng)論 0 13
  • Spring Cloud為開(kāi)發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見(jiàn)模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)择葡,斷路器紧武,智...
    卡卡羅2017閱讀 134,654評(píng)論 18 139