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

CAP定理和BASE理论

CAP定理

CAP定理,也称为布鲁尔定理(Brewer’s Theorem),是分布式系统设计中的一个基本原理。它指出在分布式系统中,一致性(Consistency)、可用性(Availability)和分区容忍性(Partition tolerance)三个要素中,任意时刻只能满足其中的两个。

图文解释

在分布式系统中,由于网络分区(P)的存在,我们只能在一致性(C)和可用性(A)之间做出选择。以下是CAP定理的图解:

      +-------+      vs      +-------+|       |            |       |
C  ----|  一致性|            |  可用性|---- A|       |            |       |+-------+      vs      +-------+

CP和AP对比:ZK和Eureka

ZK(ZooKeeper)- CP模型

ZooKeeper遵循CP原则,即在网络分区发生时,为了保证一致性,可能会牺牲可用性。当ZooKeeper集群中的Master节点因为网络问题与其他节点失去联系时,会进行Leader选举,期间整个集群可能不可用,直到选出新的Leader。

Eureka - AP模型

Eureka遵循AP原则,即在网络分区发生时,为了保证可用性,可能会牺牲一致性。Eureka允许服务实例注册信息在一段时间内是陈旧的,但仍然可以对外提供服务,即使某些实例可能已经下线。

BASE理论

BASE理论是对CAP理论中AP方案的一个补充,它强调基本可用(Basically Available)、软状态(Soft state)和最终一致性(Eventually consistent)。

图文解释

BASE理论的核心可以用以下图表表示:

      +----------------+     +----------------+     +----------------+|                |     |                |     |                |
B  ----|  基本可用(BA)   |     |  软状态(SS)     |     |  最终一致性(EC) ||                |     |                |     |                |+----------------+     +----------------+     +----------------+

在实际应用中,比如电商购物车系统,用户可以将商品添加到购物车,然后进行结算和支付。这涉及到对购物车中商品数量、价格等数据的操作和更新。为了确保数据的最终一致性,可以采取以下措施:在用户操作后,通过异步消息队列更新库存和订单信息,确保在系统出现故障时,数据最终能够达到一致状态。

下面是springboot,springCloudalibaba等视频地址

<!-- springboot,springboot整合redis,整合rocketmq视频: -->
https://www.bilibili.com/video/BV1nkmRYSErk/?vd_source=14d27ec13a4737c281b7c79463687112<!-- springcloudalibaba,openfeign,nacos,gateway,sso视频:-->
https://www.bilibili.com/video/BV1cFDEYWEkY/?vd_source=14d27ec13a4737c281b7c79463687112<!-- vue+springboot前后端分离视频:-->
https://www.bilibili.com/video/BV1JLSEYJETc/?vd_source=14d27ec13a4737c281b7c79463687112<!-- shiro视频:-->
https://www.bilibili.com/video/BV1YVUmYJEPi/?vd_source=14d27ec13a4737c281b7c79463687112
http://www.lryc.cn/news/497752.html

相关文章:

  • 笔记软件:我来、思源笔记、Obsidian、OneNote
  • 试探互联网如何工作?
  • 【c++笔试强训】(第三十篇)
  • 微信小程序购物车全选反选功能以及合计
  • vue-qr在线生成二维码组件(vue2版本)
  • 大语言模型技术相关知识-笔记整理
  • SCP命令实现Linux中的文件传输
  • linux环境中后台运行java程序
  • Go学习:变量
  • 在Unity编辑模式下运行Mono中的方法
  • Y20030028 JAVA+SSM+MYSQL+LW+基于JAVA的考研监督互助系统的设计与实现 源代码 配置 文档
  • MATLAB期末复习笔记(下)
  • 「Mac畅玩鸿蒙与硬件37」UI互动应用篇14 - 随机颜色变化器
  • MySql:理解数据库
  • 学习笔记051——SpringBoot学习2
  • crush rule 20 type does not match pool
  • BA是什么?
  • 通过docker 搭建jenkins环境;
  • 10-高级主题
  • harbor常见问题及解决方法分享
  • 行列式与线性方程组解的关系
  • 四、自然语言处理_02RNN基础知识笔记
  • Spring 容器管理 Bean
  • SpringBoot开发——Spring Boot3.4 强大的结构化日志记录
  • 信号和槽思维脑图+相关练习
  • Unity Feel插件快速入门
  • 数据链路层(四)---PPP协议的工作状态
  • 【C++】入门【六】
  • UE5 C++ 不规则按钮识别,复选框不规则识别 UPIrregularWidgets
  • Elasticsearch Serverless 现已正式发布