一、定义
C:Consistenct(强一致性)
A:Availiablity(高可用性)
P:Partition tolerance(分区容错性)
二、经典CAP图

三、CAP的3进2
CAP理论的核心是:一个分布式系统不可能同时很好的满足一致性、可用性和分区容错性这三个需求,最多只能同时较好的满足两个。而由于当前的网络硬件肯定会出现延迟丢包等问题,分区容忍性是我们必须需要实现的,所以我们只能在一致性和可用性之间进行权衡。
如:CA 传统Oracle数据库、AP 大多数网站架构的选择、CP Redis、Mongodb
注意:分布式架构的时候必须做出取舍。
满足 CA 原则、满足 CP 原则和满足 AP 原则的选择:
CA - 单点集群,满足一致性,可用性的系统,通常在可扩展性上不太强大。
CP - 满足一致性,分区容忍性的系统,通常性能不是特别高。
AP - 满足可用性,分区容忍性的系统,通常可能对一致性要求低一些。
四、BASE是什么
BASE其实是下面三个术语的缩写:
基本可用(Basically Available):响应时间上的损失和功能上的损失
软状态(Soft state):允许系统中的数据存在中间状态
最终一致(Eventually consistent):系统能够保证在没有其他新的更新操作的情况下,数据最终一定能够达到一致的状态
它的思想是通过让系统放松对某一时刻数据一致性的要求来换取系统整体伸缩

CAP定理指出分布式系统无法同时确保一致性、可用性和分区容错性。通常,由于网络延迟和分区容错性的必要性,系统需要在一致性和可用性之间作出权衡。例如,Oracle数据库倾向于CA,网站架构选择AP,而Redis和Mongodb更偏向CP。BASE理论则主张在分布式环境中,通过牺牲强一致性换取系统可用性和伸缩性,接受基本可用、软状态和最终一致性。
最低0.47元/天 解锁文章
523

被折叠的 条评论
为什么被折叠?



