简单谈谈 分布式基础理论 CAP、BASE、酸碱平衡

CAP 理论

在一个分布式系统中,最多只能同时满足 一致性(C)、可用性(A) 和分区容错(P)三项中的两项。

在CAP理论中,有且只可能有两种情况,分别是CP和AP

比如说在一个mysql主从集群,在初始的时候,master和slave中的数据是一致的。

如果主从同步配置是异步复制,那么修改不会马上同步到slave中,如果这个时候有一个读请求达到slave,那么将返回旧数据。

在这个情况下,只能保证可用性,不能保证一致性。

如果要求一致性,那么需要将同步方式配置成同步,在这种情况下,在同步的时候,会降低可用性。

所以,在分布式系统中,只可能存在CP和AP,不可能是CA。

BASE 理论

Base 是 由 基本可用(Basically Available)、软状态(soft state)、和最终一致性(Eventually consistent)三个单词组成。

由于在CAP理论中,CA不可能同时达成,通过加入软状态,然后将一致性妥协成最终一致性,将可用性妥协成基本可用,最终让可用性和一致性可以同时达成。

比如下单场景,在下单的时候,需要去进行支付,由于支付的流程不是同步完成的,因此,在这个过程中,引入一个【支付中】状态,这个状态就是软状态。

最终收到第三方的回调,完成支付,将状态修改为支付完成。

这样支付过程中系统是可用的,同时一致性也可以得到保障

酸碱平衡 理论

酸碱平衡理论就是ACID和BASE理论之间的平衡关系,酸就是ACID,代表强一致;碱就是BASE,可以牺牲一定的一致性来换取系统的高可用。

在一个系统中,需要根据实际情况,来判断是需要强一致,还是可以牺牲一致性来提高可用性。

比如说,在一个交易系统中,A账户的出账和B账户的入账,是需要高一致的,但是交易完成后的通知是可以牺牲一致性来提高可用性。

相关推荐
Jing_jing_X5 小时前
AI分析不同阶层思维 二:Spring 的事务在什么情况下会失效?
java·spring·架构·提升·薪资
jump_jump11 小时前
SaaS 时代已死,SaaS 时代已来
前端·后端·架构
一条咸鱼_SaltyFish12 小时前
[Day14] 微服务开发中 `contract - common` 共享库的问题排查与解决
程序人生·微服务·架构·开源软件·ddd·个人开发·ai编程
一只鱼丸yo13 小时前
从单体到微服务:一次真实迁移实战
微服务·云原生·架构
桌面运维家13 小时前
vDisk VOI架构IO瓶颈怎么办?Windows优化实战
windows·架构
前端不太难14 小时前
从本地到多端:HarmonyOS 分布式数据管理实战详解
分布式·状态模式·harmonyos
Yeats_Liao14 小时前
MindSpore开发之路(二十五):融入开源:如何为MindSpore社区贡献力量
人工智能·分布式·深度学习·机器学习·华为·开源
Blossom.11814 小时前
Transformer架构优化实战:从MHA到MQA/GQA的显存革命
人工智能·python·深度学习·react.js·架构·aigc·transformer
Python_Study202515 小时前
制造业数据采集系统选型指南:从技术挑战到架构实践
大数据·网络·数据结构·人工智能·架构
喵叔哟15 小时前
8.健康检查与监控
架构·.net