CAP定理的含义

CAP定理的含义目录定理解读如何抉择 1998 年 加州大学的计算机科学家 EricBrewer 提出了分布式系统的三个指标 C Consistency 一致性 在分布式系统中的所有数据备份 在同一时刻具有同样的值 所有节点在同一时刻读取的数据都是最新的数据副本 allnodesseet A Availability 可用性 好

目录

定理解读

如何抉择


1998年,加州大学的计算机科学家 Eric Brewer 提出了分布式系统的三个指标:

C:Consistency,一致性。在分布式系统中的所有数据备份,在同一时刻具有同样的值,所有节点在同一时刻读取的数据都是最新的数据副本(all nodes see the same data at the same time)。

A:Availability ,可用性,好的响应性能。完全的可用性指的是在任何故障模型下,服务都会在有限的时间内处理完成并进行响应(Reads and writes always succeed)。

P:Partition Tolerance ,分区容错性,即分布式系统在遇到某些节点或网络分区故障的时候,仍然能够对外提供满足一致性或可用性的服务。分区容错性要求一个分布式系统中有某一个或者几个节点故障时,其他剩下的节点还能够正常运转并对外提供服务,对于用户而言并没有什么体验上的影响。

Eric Brewer 指出任何分布式系统只可同时满足CAP三个指标中的两个,无法三者兼顾,这个结论就叫做 CAP 定理。

CAP定理的含义

定理解读

分布式的服务化系统都需要满足分区容忍性,那么我们必须在一致性(C)和可用性(A)之间进行权衡。在网络分区故障发生时,两个分布式节点之间无法进行通信,那么我们对一个节点进行的修改操作将无法同步到另外一个节点,所以数据的一致性(C)将无法满足,因为两个分布式节点的数据不再保持一致。除非我们牺牲可用性(A),也就是在网络分区故障发生时,暂停分布式系统对外提供修改数据服务,直到网络状况完全恢复正常再继续对外提供修改数据服务。

CP满足的情况下,A不能满足的原因:

若要满足一致性(C)就需要在多个分布式节点之间进行数据同步,在数据同步完成之前整个系统都将不可用。节点数量越多分区容错性(P)越好,同时数据同步所耗费的时间自然也就越长,从而无法在有限的时间内完成请求响应,导致可用性(A)不能满足。

CA满足的情况下,P不能满足的原因:

若要满足一致性(C)就需要在多个分布式节点之间进行数据同步,在数据同步完成之前整个系统都将不可用。需同步的节点数量越多,数据同步所需耗费的时间越长,可用性(A)也越差。若要同时保证可用性(A),那么需同步的节点数量就需要尽量减少,从而导致分区容错性(P)无法满足。

AP满足的情况下,C不能满足的原因:

节点的数量越多,分区容错性(P)越好,节点间数据同步所需耗费的时间越长,若要在有限的时间内完成请求响应即保证可用性(A),那么数据就可能不能及时地同步到其他节点,从而无法保证节点间的数据一致性(C)。

如何抉择

对于现如今大多数的互联网应用场景,都倾向于采用分布式微服务架构,它们通常节点众多、部署相对分散,随着集群规模变得越来越大,节点故障、网络故障已是常态。

在这种情况下,对于那些对数据一致性(C)要求不高的场景,例如电商系统,我们只需要保证分区容错性(P)和可用性(A),对于数据一致性(C)退而求其次仅保证数据的最终一致性即可。这虽然会某些地方影响客户体验,但并不会达到造成用户流失的严重程度。

对于像银行系统这类对数据一致性(C)要求较高的场景,数据一致性(C)必须保证。网络发生故障宁可停止服务(或者只读不写),这是保证分区容错性(P)和数据一致性(C),舍弃可用性(A)。

目前比较主流的注册中心有 Zookeeper、Eureka、Consul、Etcd 等,以Zookeeper 和Eureka为例, 在进行注册中心选择时,CAP又该如何抉择呢?

Zookeeper:CP设计,保证了一致性,集群搭建的时候,某个节点失效,则会进行选举新的Leader,或者半数以上节点不可用,则无法提供服务,因此可用性(A)没法满足。

Eureka:AP设计,无主从节点,一个节点挂了,自动切换其他节点继续使用,去中心化,但数据一致性(C)不满足。

在分布式系统中分区容错性(P)肯定要满足,所以只能在CA中二选一, 没有最好的选择,只有更适合的,我们需要根据自己的业务场景来进行架构设计:

  • 如果要求一致性,则选择 Zookeeper,如金融行业
  • 如果要求可用性,则选择 Eureka,如电商系统

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/222209.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月17日 下午4:19
下一篇 2026年3月17日 下午4:19


相关推荐

  • VBoxManage常用命令用法

    VBoxManage常用命令用法VBoxManage命令常用用法系统环境:CentOS6.3x86_64VirtualBox版本:4.2.8VirtualBox扩展版本:4.2.8增加一个新的扩展包VBoxManageextpackinstall<.vbox-extpack>卸载指定扩展包VBoxManageextpackuninstall<name>显示已安装的扩展包VBoxManagelistextpacks移除安装扩展包失败或卸载扩展包失败时可能遗留下来的文件和

    2022年6月9日
    37
  • webstorm 格式化代码 快捷键「建议收藏」

    webstorm 格式化代码 快捷键「建议收藏」ctrlaltl

    2022年5月1日
    88
  • Android开发:IBinder对象在进程间传递的形式[通俗易懂]

    2019独角兽企业重金招聘Python工程师标准>>>…

    2022年4月12日
    253
  • winform 安装部署

    winform 安装部署1 新建安装部署项目打开 VS 点击新建项目 选择 其他项目类型 安装与部署 安装向导 安装项目也一样 然后点击确定 2 安装向导关闭后打开安装向导 点击下一步 或者直接点击完成 3 开始制作安装向导完成后即可进入项目文件夹 双击 应用程序文件夹 在右边的空白处右击 选择添加 文件 将你的做的应用程序的可执行文件和相应的类库和组件添加进来 然后右击你的文件 创建快捷方式 然后把快

    2026年3月26日
    2
  • java get请求 302_HTTP 302错误和HTTP 404错误浅析

    java get请求 302_HTTP 302错误和HTTP 404错误浅析HTTP 返回状态码的含义比较丰富 随着 HTTP 版本的变化 状态码也在逐渐增加 以满足越来越多的状态信息传递 302 错误表示被请求的资源暂时转移 Movedtempora 然后会给出一个转移后的 URL 而浏览器在处理服务器返回的 302 错误时 原则上会重新建立一个 TCP 连接 然后再取重定向后的 URL 的页面 但是如果页面存在于缓存中 则不重新获取 404 错误表示无法找到请求的资源 一般来说是文

    2026年3月18日
    3
  • Java之矩阵求秩

    Java之矩阵求秩publicclassMatrixRank{publicstaticintRank(double[][]Matrix,interror_,intList){ intn=List; intm=Matrix.length; inti=0; inti1; intj=0; intj1; double

    2022年5月18日
    68

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号