第六章 分布式架构CAP理论

  • CAP定理: 指的是在⼀个分布式系统中,Consistency(⼀致性)、 Availability(可⽤性)、Partitiontolerance(分区容错性),三者不可同时获得
    ⼀致性(C):所有节点都可以访问到最新的数据
    可⽤性(A):每个请求都是可以得到响应的,不管请求是成功还是失败
    分区容错性(P):除了全部整体⽹络故障,其他故障都不能导致整个系统不可⽤
  • CAP理论就是说在分布式存储系统中,最多只能实现上⾯的两点。⽽由于当前的⽹络硬件肯定会出现延迟丢包等问题,所以分区容忍性是我们必须需要实现的。所以我们只能在⼀致性和可⽤性之间进⾏权衡
    在这里插入图片描述CA: 如果不要求P(不允许分区),则C(强⼀致性)和A(可⽤性)是可以保证的。但放弃P的同时也就意味着放弃了系统的扩展性,也就是分布式节点受限,没办法部署⼦节点,这是违背分布式系统设计的初衷的
    CP: 如果不要求A(可⽤),每个请求都需要在服务器之间保持强⼀致,⽽P(分区)会导致同步时间⽆限延⻓(也就是等待数据同步完才能正常访问服务),⼀旦发⽣⽹络故障或者消息丢失等情况,就要牺牲⽤户的体验,等待所有数据全部⼀致了之后再让⽤户访问系统
    AP:要⾼可⽤并允许分区,则需放弃⼀致性。⼀旦分区发⽣,节点之间可能会失去联系,为了⾼可⽤,每个节点只能⽤本地数据提供服务,⽽这样会导致全局数据的不⼀致性
  • 常⻅注册中⼼:zk、eureka、nacos
 NacosEurekaConsulZookeeper
⼀致性协议CP+APAPCPCP
健康检查TCP/HTTP/MYSQL/Client Beat⼼跳TCP/HTTP/gRPC/CmdKeep Alive
雪崩保护
访问协议HTTP/DNSHTTPHTTP/DNSTCP
SpringCloud集成⽀持⽀持⽀持⽀持
  • Zookeeper:CP设计,保证了⼀致性,集群搭建的时候,某个节点失效,则会进⾏选举⾏的leader,或者半数以上节点不可⽤,则⽆法提供服务,因此可⽤性没法满⾜
  • Eureka:AP原则,⽆主从节点,⼀个节点挂了,⾃动切换其他节点可以使⽤,去中⼼化
  • 结论
    分布式系统中P,肯定要满⾜,所以只能在CA中⼆选⼀
    没有最好的选择,最好的选择是根据业务场景来进⾏架构设计
    如果要求⼀致性,则选择zookeeper/Nacos,如⾦融⾏业 CP
    如果要求可⽤性,则Eureka/Nacos,如电商系统 AP
    CP : 适合⽀付、交易类,要求数据强⼀致性,宁可业务不可⽤,也不能出现脏数据
    AP: 互联⽹业务,⽐如信息流架构,不要求数据强⼀致,更想要服务可⽤
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值