CAP Theorem

CAP 定理

一致性(consisitency), 可用性(availability) 和 分区容错(partition tolerance) 只能保证两个, 三者不可得兼.

C(consistency)A(availability)P(partition tolerance)
每个用户都能接收到最新的一致的信息或者错误每个用户都能接收到非错误信息, 但不一定一致或者是最新的即使部分分区出现问题, 整个系统还是能运行

一般而言, 分布式系统都有多个分区, 可以想像:
多台电脑组成一个分布式系统, 一台电脑宕机了, 但是别的电脑可能还是能运行.1

  • 这时候如果需要满足一致性, 那么数据库之间进行同步的时候, 必然需要确保原子性2,无法满足可用性.
  • 如果需要满足可用性, 那么不同数据库之间只能暂缓同步, 有请求先处理3 ,无法满足一致性

如果想要同时满足一致性和可用性, 那么最简单的方式是这个分布式系统只有一台电脑, 这样就不满足分区容错了4.


参考
维基百科


  1. 也就是满足了P, 需要在A和C之间选择 ↩︎

  2. 因为在同步过程中是不能返回信息的(或者返回一个错误). ↩︎

  3. 所以不同用户请求到的数据可能不一样 ↩︎

  4. 因为这台电脑宕机了整个系统就不能运行了 ↩︎

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值