BASE理論分析

1.什么是BASE理論

???BASE全稱:Basically Available(基本可用)Soft state(軟狀態(tài)),和 Eventually consistent(最終一致性)汉匙。
???CAP 不可能同時(shí)滿足逼庞,而分區(qū)容錯(cuò)是對于分布式系統(tǒng)而言又是必須的威根。
???Base 理論是對 CAP 中一致性和可用性權(quán)衡的結(jié)果终娃,是基于 CAP 定理逐步演化而來的肿男。其核心思想是:既是無法做到強(qiáng)一致性(Strong consistency)纲堵,但每個(gè)應(yīng)用都可以根據(jù)自身的業(yè)務(wù)特點(diǎn)幸逆,采用適當(dāng)?shù)姆绞絹硎瓜到y(tǒng)達(dá)到最終一致性(Eventual consistency)棍辕。

2.Basically Available(基本可用)

???什么是基本可用呢?假設(shè)系統(tǒng)还绘,出現(xiàn)了不可預(yù)知的故障楚昭,但還是能用,相比較正常的系統(tǒng)而言:

???響應(yīng)時(shí)間上的損失:正常情況下的一個(gè)請求 0.5 秒即返回給用戶結(jié)果拍顷,而基本可用的請求可以在 1 秒作用返回結(jié)果抚太。

???功能上的損失:在一個(gè)電商網(wǎng)站上,正常情況下昔案,用戶可以順利完成每一筆訂單尿贫,但是到了大促期間,為了保護(hù)購物系統(tǒng)的穩(wěn)定性踏揣,可以關(guān)閉一些不重要的功能或者部分消費(fèi)者可能會(huì)被引導(dǎo)到一個(gè)降級頁面庆亡。

  1. Soft state(軟狀態(tài))

???什么是軟狀態(tài)呢?相對于原子性而言捞稿,要求多個(gè)節(jié)點(diǎn)的數(shù)據(jù)副本都是一致的又谋,這是一種 “硬狀態(tài)”。

???軟狀態(tài)指的是:允許系統(tǒng)中的數(shù)據(jù)存在中間狀態(tài)娱局,并認(rèn)為該狀態(tài)不影響系統(tǒng)的整體可用性搂根,即允許系統(tǒng)在多個(gè)不同節(jié)點(diǎn)的數(shù)據(jù)副本存在數(shù)據(jù)延時(shí)。

  1. Eventually consistent(最終一致性)

???系統(tǒng)能夠保證在沒有其他新的更新操作的情況下铃辖,數(shù)據(jù)最終一定能夠達(dá)到一致的狀態(tài),因此所有客戶端對系統(tǒng)的數(shù)據(jù)訪問最終都能夠獲取到最新的值猪叙。
???上面說軟狀態(tài)娇斩,然后不可能一直是軟狀態(tài),必須有個(gè)時(shí)間期限穴翩。在期限過后犬第,應(yīng)當(dāng)保證所有副本保持?jǐn)?shù)據(jù)一致性。從而達(dá)到數(shù)據(jù)的最終一致性芒帕。這個(gè)時(shí)間期限取決于網(wǎng)絡(luò)延時(shí)歉嗓,系統(tǒng)負(fù)載,數(shù)據(jù)復(fù)制方案設(shè)計(jì)等等因素背蟆。
???最終一致性分為 5 種:
???1. 因果一致性(Causal consistency)如果節(jié)點(diǎn) A 在更新完某個(gè)數(shù)據(jù)后通知了節(jié)點(diǎn) B鉴分,那么節(jié)點(diǎn) B 之后對該數(shù)據(jù)的訪問和修改都是基于 A 更新后的值哮幢。于此同時(shí),和節(jié)點(diǎn) A 無因果關(guān)系的節(jié)點(diǎn) C 的數(shù)據(jù)訪問則沒有這樣的限制志珍。
???2. 讀己之所寫(Read your writes)節(jié)點(diǎn) A 更新一個(gè)數(shù)據(jù)后橙垢,它自身總是能訪問到自身更新過的最新值,而不會(huì)看到舊值伦糯。其實(shí)也算一種因果一致性柜某。
???3. 會(huì)話一致性(Session consistency)會(huì)話一致性將對系統(tǒng)數(shù)據(jù)的訪問過程框定在了一個(gè)會(huì)話當(dāng)中:系統(tǒng)能保證在同一個(gè)有效的會(huì)話中實(shí)現(xiàn) “讀己之所寫” 的一致性,也就是說敛纲,執(zhí)行更新操作之后喂击,客戶端能夠在同一個(gè)會(huì)話中始終讀取到該數(shù)據(jù)項(xiàng)的最新值。
???4. 單調(diào)讀一致性(Monotonic read consistency)如果一個(gè)節(jié)點(diǎn)從系統(tǒng)中讀取出一個(gè)數(shù)據(jù)項(xiàng)的某個(gè)值后淤翔,那么系統(tǒng)對于該節(jié)點(diǎn)后續(xù)的任何數(shù)據(jù)訪問都不應(yīng)該返回更舊的值翰绊。
???5. 單調(diào)寫一致性(Monotonic write consistency)指一個(gè)系統(tǒng)要能夠保證來自同一個(gè)節(jié)點(diǎn)的寫操作被順序的執(zhí)行。

???然而办铡,在實(shí)際的實(shí)踐中辞做,這 5 種系統(tǒng)往往會(huì)結(jié)合使用,以構(gòu)建一個(gè)具有最終一致性的分布式系統(tǒng)寡具。實(shí)際上秤茅,不只是分布式系統(tǒng)使用最終一致性,關(guān)系型數(shù)據(jù)庫在某個(gè)功能上童叠,也是使用最終一致性的框喳,比如備份,數(shù)據(jù)庫的復(fù)制過程是需要時(shí)間的厦坛,這個(gè)復(fù)制過程中五垮,業(yè)務(wù)讀取到的值就是舊的。當(dāng)然杜秸,最終還是達(dá)成了數(shù)據(jù)一致性放仗。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市撬碟,隨后出現(xiàn)的幾起案子诞挨,更是在濱河造成了極大的恐慌,老刑警劉巖呢蛤,帶你破解...
    沈念sama閱讀 216,591評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件惶傻,死亡現(xiàn)場離奇詭異,居然都是意外死亡其障,警方通過查閱死者的電腦和手機(jī)银室,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人蜈敢,你說我怎么就攤上這事辜荠。” “怎么了扶认?”我有些...
    開封第一講書人閱讀 162,823評論 0 353
  • 文/不壞的土叔 我叫張陵侨拦,是天一觀的道長。 經(jīng)常有香客問我辐宾,道長狱从,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,204評論 1 292
  • 正文 為了忘掉前任叠纹,我火速辦了婚禮季研,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘誉察。我一直安慰自己与涡,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,228評論 6 388
  • 文/花漫 我一把揭開白布持偏。 她就那樣靜靜地躺著驼卖,像睡著了一般。 火紅的嫁衣襯著肌膚如雪鸿秆。 梳的紋絲不亂的頭發(fā)上酌畜,一...
    開封第一講書人閱讀 51,190評論 1 299
  • 那天,我揣著相機(jī)與錄音卿叽,去河邊找鬼桥胞。 笑死,一個(gè)胖子當(dāng)著我的面吹牛考婴,可吹牛的內(nèi)容都是我干的贩虾。 我是一名探鬼主播,決...
    沈念sama閱讀 40,078評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼沥阱,長吁一口氣:“原來是場噩夢啊……” “哼缎罢!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起考杉,我...
    開封第一講書人閱讀 38,923評論 0 274
  • 序言:老撾萬榮一對情侶失蹤屁使,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后奔则,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,334評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡蔽午,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,550評論 2 333
  • 正文 我和宋清朗相戀三年易茬,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,727評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡抽莱,死狀恐怖范抓,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情食铐,我是刑警寧澤匕垫,帶...
    沈念sama閱讀 35,428評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站虐呻,受9級特大地震影響象泵,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜斟叼,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,022評論 3 326
  • 文/蒙蒙 一偶惠、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧朗涩,春花似錦忽孽、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,672評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至识腿,卻和暖如春出革,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背覆履。 一陣腳步聲響...
    開封第一講書人閱讀 32,826評論 1 269
  • 我被黑心中介騙來泰國打工蹋盆, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人硝全。 一個(gè)月前我還...
    沈念sama閱讀 47,734評論 2 368
  • 正文 我出身青樓栖雾,卻偏偏與公主長得像,于是被迫代替她去往敵國和親伟众。 傳聞我的和親對象是個(gè)殘疾皇子析藕,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,619評論 2 354

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

  • 今日體驗(yàn):今天進(jìn)廠車輛不多基本上都是補(bǔ)胎的小活,但我們也要認(rèn)真細(xì)致的去做凳厢。 核心:做好每一件事情
    GL_212a閱讀 196評論 0 0
  • 模型查找 頁面渲染 phpstorm快速查找 文件 ctrl + shift + n 時(shí)間格式https://c...
    StevenQin閱讀 524評論 0 0