当前位置: 首页 > news >正文

CAP和BASE理论

CAP理论

CAP是 Consistency、Availability、Partition tolerance 三个词语的缩写,分别表示一致性、可用性、分区容忍性。

它指出一个分布式计算系统不可能同时满足以下三点:

• 一致性(Consistency) :等同于所有节点访问同一份最新的数据副本

• 可用性(Availability) :每次请求都能获取到非错误的响应——但是不保证获取的数据为最新数据

• 分区容忍性(Partition tolerance) :通常分布式系统的各各结点部署在不同的子网,这就是网络分区,分区相当于对通信的时限要求。系统如果不能在时限内达成数据一致性,就意味着发生了分区的情况,必须就当前操作在C和A之间做出选择。

分布式系统必须具备分区容忍性,如果不具备分区容忍性,那就是单体系统。在具备了分区容忍性的前提下,就不能同时具备一致性、可用性。

理解CAP理论的最简单方式是想象系统有两个节点A、B,两节点会同步数据,保持数据一致。

当A节点数据发生变化

要保证一致性,A将数据同步到B的时间段内,服务是不可用的。例如:A、B之间网络断开或B不可用,那么A将数据同步到B的时间就会很久,需要等网络恢复,B重启完成才能保证A、B数据一致。在同步时的时候加锁,此时无法再处理其他请求,这也属于服务不可用。

如果要保证可用性,在A将数据同步到B节点的时间段内,A、B两节点的数据是不一致的。

分布式系统只能是AP或CP两种组合。

AP模式

大部分系统会放弃一致性,追求分区容忍性、可用性。

CP模式

放弃可用性,追求分区容忍性、一致性。zookeeper在选举leader时,会停止服务,直到选举成功之后才会再次对外提供服务。

BASE理论

AP模式在实际应用中较多,AP模式舍弃一致性,保证可用性和分区容忍性,但是在实际生产中绝大多数场景都要现一致性。BASE理论是对CAP理论AP模式的拓展。

BASE 是 Basically Available(基本可用)、Soft state(软状态)和 Eventually consistent (最终一致性)三个短语的缩写。当系统出现故障,允许部分功能不可用但要保证核心功能可用,允许数据在一段时间内是不一致的,但最终达到一致状态。

基本可用:分布式系统在出现故障时,允许部分功能不可用,保证核心功能可用;允许请求响应变慢,例如:请求时间由原来的1S增加2~3S。

软状态:由于不要求强一致性,所以BASE允许系统中存在中间状态(也叫软状态),这个状态不影响系统可用。例如:订单的“支付中”。

最终一致:最终一致是指经过一段时间后,所有节点数据都将会达到一致。例如:今日退款明日到账;通过记录日志、人工排查等方将分布式系统数据改成一致状态。

http://www.lryc.cn/news/6941.html

相关文章:

  • 基于商品理解的成交能力和成交满意度优化在Lazada的实践
  • idea推送镜像到desktop报错:Cannot run program “docker-credential-desktop“ 系统找不到指定的文件。
  • hive开窗函数
  • 安全多方计算系列笔记1——前世今生
  • 16- 梯度提升分类树GBDT (梯度下降优化) (算法)
  • SpringCloud+Nacos+Gateway
  • 高通开发系列 - linux kernel内核升级msm-3.18升至msm-4.9(2)
  • Spring依赖注入与反转控制到底是个啥?
  • Linux Shell脚本讲解
  • Linux:用户空间非法指针coredump简析
  • 带你玩转Jetson之Deepstream简明教程(四)DeepstreamApp如何使用以及用于工程验证。
  • 快速搭建个人在线书库,随时随地畅享阅读!
  • 电子纸墨水屏的现实应用场景
  • 常量const、引用、指针的大杂烩
  • 宝塔搭建实战php开源likeadmin通用管理移动端uniapp源码(四)
  • Hive的分区表与分桶表内部表外部表
  • 和数集团打造《神念无界:源起山海》,诠释链游领域创新与责任
  • 小白入门模拟IC设计,如何快速学习?
  • 51单片机——中断系统之外部中断实验,小白讲解,相互学习
  • 如何设计一个秒杀系统
  • 厄瓜多尔公司注册方案
  • 安全渗透环境准备(工具下载)
  • 118.(leaflet篇)leaflet空间判断-点与geojson面图层的空间关系(turf实现)
  • 目标检测与目标跟踪算法技术汇总
  • Linux 系统启动过程
  • 【每日一题Day118】LC1124表现良好的最长时间段 | 前缀和+单调栈/哈希表
  • vue使用nprogress(进度条)
  • @NotNull 、@NotBlank、@NotEmpty区别和使用
  • Nacos——Nacos简介以及Nacos Server安装
  • Presto 文档和笔记