关于cap理论及zookeeper,eureka

cap指的是在一个分布式系统中,一致性(Consistency)、可用性(Availability)、分区容错性(Partition tolerance)。CAP 原则指的是,这三个要素最多只能同时实现两点,不可能三者兼顾。

什么是一致性?

一致性分为强一致性,弱一致性,以及最终一致性。先看下面一张图。
在这里插入图片描述
一个数据库集群中,用户先更新数据库a中的value为2,再从数据库b中读取value的值。
强一致性:指的是读取到的必须是最近一次更新的值,那么就要求数据库之间的异步复制非常迅速或者在读取的时候加锁保证读到的是最近一次更新的值
弱一致性:读取到的可以是1,也就是可以不是最近一次更新的值。
最终一致性:读取到的可以先是1,集群保证最终数据会一直,也就是最终会读取到2.

什么是可用性?

可用性指的是微服务架构中单体的服务是否可用。

什么是分区容错性?

分布式系统都会牵扯到分区容错性,也就是网络出问题时导致的功能可能不可用。
在这里插入图片描述
用户和订单在不同的地方,或者不同的网段,单个的用户微服务和订单微服务可用,但是当网络出现问题时这时用户就获取不到订单信息了,这就是分区容错性。

zookeeper保证了cap的什么?

zookeeper是一个分布式的服务框架,它本身是一个树形的文件存储系统,解决分布式系统中常见的数据管理问题,如:统一命名服务、状态同步服务、集群管理、分布式应用配置项的管理等。
上面的解释有点抽象,简单来说zookeeper=文件系统+监听通知机制。
具体关于zookeeper的入门介绍参加下面这篇技术博客。
https://blog.csdn.net/java_66666/article/details/81015302

zookeeper保证了cp
例如一个zookeeper集群,当有一个zookeeper 挂了,那其他的zookeeper 会进行 一次选举 (强一致性 : 我一定要保持数据一致性),而在此选举期间 zookeeper 是不可用的 而当前 有用户正在使用 用户就不爽了 。

eureka保证了ap

eureka保证了ap,每个eureka节点都是平等的,只要有一台 Eureka还在,就能保证注册服务可用(保证可用性),只不过查到的信息可能不是最新的,不保证强一致性。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值