CAP理论 | 青训营笔记

123 阅读2分钟

这是我参与「第五届青训营」伴学笔记创作活动的第 8 天。

一、什么是CAP理论

CAP即:

  • Consistency(一致性)
  • Availability(可用性)
  • Partition tolerance(分区容忍性)

这三个性质对应了分布式系统的三个指标:
而CAP理论说的就是:一个分布式系统,不可能同时做到这三点。

二 、 C、 A、P的含义

  1. 一致性: 对于客户端的每次读操作,要么读到的是最新的数据,要么读取失败。换句话说,一致性是站在分布式系统的角度,对访问本系统的客户端的一种承诺:要么我给您返回一个错误,要么我给你返回绝对一致的最新数据,不难看出,其强调的是数据正确。

  2. 可用性: 任何客户端的请求都能得到响应数据,不会出现响应错误。换句话说,可用性是站在分布式系统的角度,对访问本系统的客户的另一种承诺:我一定会给您返回数据,不会给你返回错误,但不保证数据最新,强调的是不出错。

  3. 分区容忍性: 由于分布式系统通过网络进行通信,网络是不可靠的。当任意数量的消息丢失或延迟到达时,系统仍会继续提供服务,不会挂掉。换句话说,分区容忍性是站在分布式系统的角度,对访问本系统的客户端的再一种承诺:我会一直运行,不管我的内部出现何种数据同步问题,强调的是不挂掉。

C、A、P的权衡

CA系统

CA型系统彻底放弃了分区容错性,从而换取强一致性与较高的性能,传统的关系型数据库都是CA系统,如MySQL、Postgresql等

CP系统

CP系统追求强一致性,因而牺牲了一定的性能,代表有Redis、Zookeeper等

AP系统

AP不要求强一致性,换取更高的性能,进一步引申出了BASE理论,代表有TiDB等