BASE理论理解

BASE理论是构建大型高可用分布式系统的基础,它包括:基本可用(BA)、软状态(S)和最终一致性(E)。BA允许在故障时损失部分可用性;S允许数据存在中间状态,同步延时;E则确保数据最终达到一致状态。最终一致性有五种变种,如因果一致性、会话一致性等,用于实现不同业务场景的需求。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

概念

BASE = BA(Basically Available) + S(Soft state) +E(Eventually consistance)

  BASE理论面向的是大型高可用高扩展的分布式系统,和传统事务的ACID的强一致模型,而是提出牺牲强一致性,来换取高可用性,并允许数据在一段时间内不一致,但最终达到一致状态。

BA基本可用

 分布式系统在出现不可预知故障的时候允许损失部分可用性

  1、响应时间上的损失:平时响应时间0.5秒,故障时1-2秒

  2、功能上的损失:如限流、服务降级

S软状态

  允许数据存在中间状态,允许系统在不同节点的数据副本之间存在同步延时(如Mysql MGR集群化部署,一主两从,牺牲强一致性换来可用性)

E最终一致性

  系统中的所有数据副本,在经过一段时间的同步后,最终能达到一个一致的状态
即使不能做到强一致,各系统应该结合自身业务特点,采用适当的方式达到最终一致性

最终一致性变种

  实际工程中,最终一致性有以下5种变种:

1、因果一致性(Causal consistency)

  进程A更新数据后通知进程B,进程B对数据的操作基于A更新后的最新值

2、Read your writes

  进程A更新数据后,访问到的值一定不比自己更新的值旧
  例:数据库先update再select,select到的不比刚才update的值版本更旧

3、会话一致性(Session consistency)

  将Read you writes限定在session生命周期内

4、单调读一致性(Monotonic read consistency)

  读取一个值后,后续读到的值都不能比该值更旧

5、单调写一致性(Monotonic write consistency)

  系统要保证来自同一进程的写操作被顺序执行

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值