現(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)既能一致又能可用夯秃。