編程 || CAP原理

現(xiàn)在的系統(tǒng)基本都是分布式的。
但其實(shí)分布式這個(gè)事兒日常能用的就是個(gè)分布式鎖比原,控制好競(jìng)爭(zhēng)狀態(tài)即可。其他的分布式數(shù)據(jù)庫(kù)杠巡、緩存春寿、消息隊(duì)列啥的,用中間件都已經(jīng)給你封裝好了忽孽。封裝好的東西干嘛還要去管它绑改,我還要去寫(xiě)二進(jìn)制和匯編嗎?

了解CAP什么的兄一,就像是做一個(gè)思維體操厘线。好的就來(lái)體操一下吧。

CAP是Consitency出革、Availabiltiy造壮、Partition tolerance的縮寫(xiě)。
Consistency是一致性,指每個(gè)節(jié)點(diǎn)的數(shù)據(jù)都一致耳璧。
Availability是可用性成箫,指永遠(yuǎn)會(huì)提供服務(wù)。
Partition tolerance是分區(qū)容忍性旨枯,指出現(xiàn)分區(qū)錯(cuò)誤時(shí)也能正常運(yùn)作蹬昌。比如一個(gè)原本所有服務(wù)都在一個(gè)大區(qū),現(xiàn)在分成了兩個(gè)小區(qū)攀隔,互不連通皂贩。

CAP就是說(shuō),這三者只能滿足其二昆汹,不能全都滿足明刷。不過(guò),既然是理論满粗,我們要知道它無(wú)非是一種概括性的總結(jié)辈末。哪天有更好的理論替代的也是有可能的,畢竟它是如此的不簡(jiǎn)潔不直觀映皆。

既然只能三選二本冲,如何去選擇呢?
在各個(gè)場(chǎng)景中劫扒,我們可以先抓一個(gè)必須要的檬洞,在從另外兩個(gè)中去取舍。

比如銀行轉(zhuǎn)賬業(yè)務(wù)沟饥,那C是必須的添怔,不一致就一定出錯(cuò)。那接下來(lái)就是A和P的選擇贤旷,我們可反過(guò)來(lái)不要A或不要P會(huì)發(fā)生什么广料。不要P就不是分布之系統(tǒng)了,確實(shí)剩下的這一臺(tái)機(jī)器只要還活著幼驶,就能提供服務(wù)艾杏,但這違背了分布式的初衷。不要A的話就意味著請(qǐng)求會(huì)一直阻塞盅藻,直到分布式系統(tǒng)完成了數(shù)據(jù)的同步购桑。總的來(lái)看氏淑,不要P是一點(diǎn)好處都沒(méi)有勃蜘,不要A還有機(jī)會(huì)挽回。所以從收益最大化角度假残,tradeoff掉那個(gè)A缭贡,所以最終是個(gè)CP服務(wù)。

對(duì)于大部分分布式系統(tǒng),P都是必須的阳惹。

有哪些系統(tǒng)A是必須的谍失,比如短視頻服務(wù),分區(qū)1提供系列1莹汤,分區(qū)2提供系列2快鱼,有啥問(wèn)題呢,但是刷不出來(lái)可就不行了吧体啰。那剩下就是CP之間取舍,P又是分布式系統(tǒng)的根本嗽仪。所以最終是AP荒勇。

再回頭看來(lái),其實(shí)都是AP和CP之間做取舍闻坚。甚至CAP原則可以再描述成:當(dāng)發(fā)生P情況時(shí)沽翔,AC如何選擇。即當(dāng)發(fā)生節(jié)點(diǎn)雙方一時(shí)聯(lián)系不上對(duì)方時(shí)窿凤,是保證一致性仅偎,還是保證可用性。

還有一個(gè)要注意的是雳殊,CAP的tradeoff其實(shí)是在考慮出問(wèn)題的情況橘沥。正常運(yùn)行的情況下,分布式系統(tǒng)既能一致又能可用夯秃。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末座咆,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子仓洼,更是在濱河造成了極大的恐慌介陶,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,576評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件色建,死亡現(xiàn)場(chǎng)離奇詭異哺呜,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)箕戳,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,515評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門(mén)某残,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人陵吸,你說(shuō)我怎么就攤上這事驾锰。” “怎么了走越?”我有些...
    開(kāi)封第一講書(shū)人閱讀 168,017評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵椭豫,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我,道長(zhǎng)赏酥,這世上最難降的妖魔是什么喳整? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 59,626評(píng)論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮裸扶,結(jié)果婚禮上框都,老公的妹妹穿的比我還像新娘。我一直安慰自己呵晨,他們只是感情好魏保,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,625評(píng)論 6 397
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著摸屠,像睡著了一般谓罗。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上季二,一...
    開(kāi)封第一講書(shū)人閱讀 52,255評(píng)論 1 308
  • 那天檩咱,我揣著相機(jī)與錄音,去河邊找鬼胯舷。 笑死刻蚯,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的桑嘶。 我是一名探鬼主播炊汹,決...
    沈念sama閱讀 40,825評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼逃顶!你這毒婦竟也來(lái)了兵扬?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,729評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤口蝠,失蹤者是張志新(化名)和其女友劉穎器钟,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體妙蔗,經(jīng)...
    沈念sama閱讀 46,271評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡傲霸,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,363評(píng)論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了眉反。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片昙啄。...
    茶點(diǎn)故事閱讀 40,498評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖寸五,靈堂內(nèi)的尸體忽然破棺而出梳凛,到底是詐尸還是另有隱情,我是刑警寧澤梳杏,帶...
    沈念sama閱讀 36,183評(píng)論 5 350
  • 正文 年R本政府宣布韧拒,位于F島的核電站淹接,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏叛溢。R本人自食惡果不足惜塑悼,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,867評(píng)論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望楷掉。 院中可真熱鬧厢蒜,春花似錦、人聲如沸烹植。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,338評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)草雕。三九已至巷屿,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間促绵,已是汗流浹背攒庵。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,458評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工嘴纺, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留败晴,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,906評(píng)論 3 376
  • 正文 我出身青樓栽渴,卻偏偏與公主長(zhǎng)得像尖坤,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子闲擦,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,507評(píng)論 2 359

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