分布式CAP理论

CAP 定理(CAP Theorem)是分布式系统理论中的一个核心概念,由 Eric Brewer 提出,用于描述分布式系统在设计时面临的权衡。CAP 代表以下三个特性:

  1. 一致性(Consistency):所有节点在同一时间看到的数据是一致的,即所有读操作都返回最近的写操作结果。
  2. 可用性(Availability):系统能够在合理时间内响应每个请求,无论成功还是失败。
  3. 分区容错性(Partition Tolerance):系统能够在网络分区(节点间通信中断)的情况下继续运行

*分区容错性(P)**在分布式系统中几乎是不可避免的,因为网络故障或延迟无法完全消除。因此,实际设计中往往在 CP 和 AP 之间进行选择。

  • CP(一致性 + 分区容错性)
    • 优先保证数据一致性和分区容错性,牺牲可用性。
    • 当网络分区发生时,系统可能会拒绝某些请求,以确保数据一致。
    • 适用场景:银行系统、需要强一致性的金融系统。
    • 示例:MongoDB(某些配置)、HBase、京东、淘宝的部分库存系统(库存不一致防止超卖)。
  • AP(可用性 + 分区容错性)
    • 优先保证可用性和分区容错性,牺牲一致性。
    • 网络分区时,系统仍可响应,但不同节点的数据可能不一致(最终一致性)。
    • 适用场景:社交媒体、内容分发网络(如 CDN)。
    • 示例:Twitter 的时间线系统、Amazon 的推荐系统、YouTube。
相关推荐
雨中飘荡的记忆1 小时前
大流量下库存扣减的数据库瓶颈:Redis分片缓存解决方案
java·redis·后端
NineData2 小时前
数据库迁移总踩坑?用 NineData 迁移评估,提前识别所有兼容性风险
数据库·程序员·云计算
开心就好20252 小时前
UniApp开发应用多平台上架全流程:H5小程序iOS和Android
后端·ios
悟空码字2 小时前
告别“屎山代码”:AI 代码整洁器让老项目重获新生
后端·aigc·ai编程
小码哥_常3 小时前
大厂不宠@Transactional,背后藏着啥秘密?
后端
奋斗小强3 小时前
内存危机突围战:从原理辨析到线上实战,彻底搞懂 OOM 与内存泄漏
后端
小码哥_常3 小时前
Spring Boot接口防抖秘籍:告别“手抖”,守护数据一致性
后端
心之语歌3 小时前
基于注解+拦截器的API动态路由实现方案
java·后端
None3213 小时前
【NestJs】基于Redlock装饰器分布式锁设计与实现
后端·node.js
初次攀爬者3 小时前
Kafka + KRaft模式架构基础介绍
后端·kafka