分布式CAP定理和BASE定理

CAP定理

目前的大型网站系统几乎都是分布式的,而分布式系统难以实现整个系统的强一致性。
1998年,加州大学的计算机科学家 Eric Brewer 提出,分布式系统有三个指标:

  • Consistency 一致性
  • Availability 可用性
  • Partition Tolerance 分区容错

Eric Brewer表示这三个指标不可能同时做到。这个结论就叫做 CAP 定理。
原文见参考资料,有图解。

C 一致性

一致性指标要求用户的读写操作始终正确,即写入的数据在读出来时与写入时一致。
可以理解为主库写入从库读出时需要保证从库已同步主库数据。

A 可用性

可用性指标要求每个正常请求必须有正常的响应,不可忽略。
可以理解为像主库从库请求,都得返回正常响应。

P 分区容错

由于分布式系统的特性,服务器间的通信可能出现异常,分区容错指标需要兼容这种异常情况。
可以理解为主从库网络断连,要兼容主库写入而从从库读的情况。

Eric Brewer证明不可兼容

假设C、A、P同时满足,即读写结果正确、请求有正常响应、分区容错。
验证流程:

  1. 客户端将数据写入主库
  2. 主库与从库网络断连,同步失败
  3. 客户端从从库读数据

此时分区容错如果不能保证,系统就崩了;
如果要保证读写结果始终正确,就不能在从库返回,因为从库不知道正确结果;
如果要返回结果,那结果肯定不正确;
综上,CAP无法同时保证。

CAP如何取舍

在分布式系统中,一般而言网络(或节点)出现问题是常态,系统崩溃是不能接受的,所以分区容错是必须要保证的。
在此基础上,只能从C.一致性和A.可用性中作出取舍。

CA舍弃P
单点系统基本是这样,但不分区不能算分布式系统了。

CP舍弃A
保证强一致性舍弃可用性,那么在网络异常期间服务(或部分服务)可能不可用。

AP舍弃C
保证可用而舍弃强一致性,在网络异常期间服务可以正常使用,但数据可能不是实时同步的而是本地旧数据。

可见,总要舍弃一个的时候,保证AP舍弃C是比较合理且使用范围比较广的。在这种情况下,服务在异常期间始终保持可用,但局部数据不一致;在异常结束后数据可以恢复一致。
绝大多数分布式网站系统在三者中的取舍是 P.分区容错>A.可用>C.数据强一致,因为很多时候短时间数据不一致对于用户而言是可接受的。
一些特殊系统比如金融行业等的分布式系统,可能对数据强一致要求比较高,在无法全部保证时会舍弃可用性,暂停服务。

BASE定理

在CAP定理的基础上,延伸出比较现实的用于保证分布式系统高可用的BASE定理。
BASE是指服务保证基本可用(Basically Available),可以存在软状态(Soft State),最终能够达到一致性(Eventual Consistency)。
BASE定理是当前分布式系统牺牲强一致性确保高可用的支撑思路。

Basically Available 基本可用

出现系统故障时,允许服务部分不可用。
比如在某网站点了个赞,但是5秒之后才出现反馈,而且是“服务异常请重试”。这表示服务确实有异常,但并非完全不可用——至少还有反馈。

Soft State 软状态

允许系统存在可用的中间状态。
即允许在数据同步期间,用户的同一请求得到的数据不同(但服务整体还可用),因为处理请求的服务的数据同步状态可能不同。

Eventual Consistency 最终一致

强调系统数据最终能够达到一致状态,相对强一致性的系统,这是一种弱一致性。
也就是说虽不要求实时一致的数据同步,但最终应当进入一致状态。

总结

分布式CAP定理和BASE定理启发我们,分布式系统的理想状态是无法实现的。但我们可以做出取舍,设计出高可用兼顾部分一致性的分布式系统:

  • 分布式系统需要保证P.分区容错
  • 当CAP无法全部满足时,在CA中取舍,但舍并不代表完全不要
  • 对于我等Web开发而言,尽量保证A.可用性,但并不代表必须100%保证可用,也并不代表不需要保证C.一致性
  • 尽量保证异常状态下系统基本可用
  • 尽量保证中间状态下系统可用

参考资料

An Illustrated Proof of the CAP Theorem
分布式系统原理九:CAP理论和BASE理论 | 成长之路

本文搬自我的博客,欢迎参观!

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,133评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,682评论 3 390
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,784评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,508评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,603评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,607评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,604评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,359评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,805评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,121评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,280评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,959评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,588评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,206评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,442评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,193评论 2 367
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,144评论 2 352

推荐阅读更多精彩内容