一壁顶、什么是CAP理論
Consistency(一致性)
Availability(可用性)
Partition tolerance(分區(qū)容忍性)
這三個性質對應了分布式系統(tǒng)的三個指標:
而CAP理論說的就是:一個分布式系統(tǒng)茅茂,不可能同時做到這三點苍匆。如下圖:
二 朋魔、 C券敌、 A唾戚、P的含義
一致性:對于客戶端的每次讀操作,要么讀到的是最新的數(shù)據(jù)待诅,要么讀取失敗叹坦。換句話說,一致性是站在分布式系統(tǒng)的角度卑雁,對訪問本系統(tǒng)的客戶端的一種承諾:要么我給您返回一個錯誤募书,要么我給你返回絕對一致的最新數(shù)據(jù)轧钓,不難看出,其強調的是數(shù)據(jù)正確锐膜。
可用性:任何客戶端的請求都能得到響應數(shù)據(jù)毕箍,不會出現(xiàn)響應錯誤。換句話說道盏,可用性是站在分布式系統(tǒng)的角度而柑,對訪問本系統(tǒng)的客戶的另一種承諾:我一定會給您返回數(shù)據(jù),不會給你返回錯誤荷逞,但不保證數(shù)據(jù)最新媒咳,強調的是不出錯。
分區(qū)容忍性:由于分布式系統(tǒng)通過網(wǎng)絡進行通信种远,網(wǎng)絡是不可靠的涩澡。當任意數(shù)量的消息丟失或延遲到達時,系統(tǒng)仍會繼續(xù)提供服務坠敷,不會掛掉妙同。換句話說,分區(qū)容忍性是站在分布式系統(tǒng)的角度膝迎,對訪問本系統(tǒng)的客戶端的再一種承諾:我會一直運行粥帚,不管我的內部出現(xiàn)何種數(shù)據(jù)同步問題(數(shù)據(jù)延遲到達或者丟失),強調的是不掛掉限次。
三芒涡、權衡 C、A
之前提到,CAP理論說一個分布式系統(tǒng)不可能同時滿足C卖漫、A费尽、P這三個特性。那么我們就來分析C羊始、A旱幼、P的權衡吧。
Note:其實這里有個關于CAP理論理解的誤區(qū)店枣。不要以為在所有時候都只能選擇兩個特性速警。在不存在網(wǎng)絡失敗的情況下(分布式系統(tǒng)正常運行時),C和A能夠同時保證鸯两。只有當網(wǎng)絡發(fā)生分區(qū)或失敗時,才會在C和A之間做出選擇长豁。
對于一個分布式系統(tǒng)而言钧唐,P是前提,必須保證匠襟,因為只要有網(wǎng)絡交互就一定會有延遲和數(shù)據(jù)丟失钝侠,這種狀況我們必須接受该园,必須保證系統(tǒng)不能掛掉。所以只剩下C帅韧、A可以選擇里初。要么保證數(shù)據(jù)一致性(保證數(shù)據(jù)絕對正確),要么保證可用性(保證系統(tǒng)不出錯)忽舟。
當選擇了C(一致性)時双妨,如果由于網(wǎng)絡分區(qū)而無法保證特定信息是最新的,則系統(tǒng)將返回錯誤或超時叮阅。
當選擇了A(可用性)時刁品,系統(tǒng)將始終處理客戶端的查詢并嘗試返回最新的可用的信息版本,即使由于網(wǎng)絡分區(qū)而無法保證其是最新的浩姥。