初探CAP定理及其不可兼得性

一、对CAP定理的理解

CAP定理是分布式系统设计的核心理论。由Eric Brewer在2000年提出,后由Gilbert和Lynch在2002年严格证明。分别是指Consistency一致性,Aavailability可用性,Partition Tolerance分区容忍性。

  • Consistency一致性,是指数据在多个副本间是保持一致的。或者说节点在同一时间看到相同的数据,即强一致性。
  • Availability可用性,指每个请求都能得到非错的响应。非错是指不保证获得的数据是最新的。
  • Partition Tolerance是指当分布式系统出现网络分区时,仍然能提供对外服务。

二、为什么说CAP不可兼得?

Cap理论表示一个分布式系统不可能同时满足不能CAP三个条件。分布式系统一定要满足Partition Tolerance分区容忍性。如果不满足p,也就是不存在分区,那么就意味着要将所有的服务都放在一个服务器上,这时这个系统也不能称为分布式系统了。

C和A权衡和选择最主要看要达到什么样程度的一致性。

如果要达到强一致性,那么就必须满足C;如果要达到一般一致性,更多考虑可用性,那么就更多要考虑A。

而C和A是不可能同时共存的。如果要保证C强一致性,因为主节点与副本之间存在数据同步的过程,必然导致系统的阻塞,这时候的系统处于不可用的状态即不满足A。

如果要保证A可用性,则不允许系统存在阻塞的情况,此时会出现访问到旧数据的情况,即会导致短暂的不一致。

综合考虑下来。总共只有两种模型存在,即CP和AP。

相关推荐
byte轻骑兵4 天前
【LE Audio】CAP精讲[13]: Central侧LE连接建立全流程解析
人工智能·音视频·cap·le audio·低功耗音频
byte轻骑兵6 天前
【LE Audio】CAP精讲[12]: 从通告到连接,LE外设连接建立全流程拆解
人机交互·cap·le audio·蓝牙音频·低功耗音频
我心飞翔@坚持不懈7 天前
高并发高可用电商平台交易架构实战(避坑)指南
高并发·架构设计·高可用·分布式系统·电商架构·架构避坑
better_liang9 天前
每日Java面试场景题知识点之-数据库与缓存的一致性
java·数据库·redis·面试·分布式系统·缓存一致性·cache aside
一切皆是因缘际会10 天前
从模型竞赛到全域智能的时代跃迁
人工智能·深度学习·ai·分布式系统
这是谁的博客?12 天前
微服务架构设计模式深度解析:从拆分策略到容灾机制
微服务·设计模式·云原生·架构·架构设计·后端开发·分布式系统
上善若水-学者至上15 天前
CAP原理饭呢西
cap
西***634716 天前
讯维分布式系统管控软件:理解指挥中心信号调度的底层逻辑
分布式系统·指挥调度
西***634718 天前
讯维分布式可视化控制系统:重塑应急调度的智能响应体系
分布式系统·分布式可视化系统·分布式输入输出节点
西***634718 天前
讯维分布式双路节点:国产音视频核心硬件,筑牢指挥中心与高端会议数字底座
分布式系统·分布式双路节点·音视频分布式