最近有时间研究分布式架构,因为公司使用的Zookeeper,并没有使用Spring Cloud Eureka,所以想探究一下他们之间的区别,于是看到简书里的文章:Spring Cloud Eureka简介及与Zookeeper对比,明显的区别可能就是Zookeeper为CP设计,而Eureka为AP设计,但是对CAP/AP/CP很不理解,于是查阅资料,做一个简单的了解。

Eureka服务治理机制与Dubbo服务治理机制的比较

Feature Eureka Zookeeper
服务健康检查 可配支持 (弱)长连接,keepalive
CAP AP CP
watch支持(客户端观察到服务提供者变化) 支持 long polling/大部分增量 支持
自我保护 支持 -
客户端缓存 支持 -
自身集群的监控 metrics -

Eureka支持健康检查,自我保护等

Zookeeper为CP设计,Eureka为AP设计。作为服务发现产品,可用性优先级较高,一致性的特点并不重要,宁可返回错误的数据,也比不反回结果要好得多。

服务列表变更Zookeeper服务端会有通知,Eureka则通过长轮询来实现,Eureka未来会实现watch机制

  • 分区容错性(Partition tolerance) : 分布式系统出现网络分区的时候,仍然能够对外提供服务。

我们是分布式系统,很有可能出现网络分区。但是出现网络分区的时候,我们仍希望系统能够对外提供响应,因此P是一定要保证的。当发生网络分区的时候,如果我们要继续服务(保证P),那么强一致性和可用性只能 2 选 1。

大家知道,在分布式环境下,为了保证系统可用性,通常都采取了复制的方式,避免一个节点损坏,导致系统不可用。那么就出现了每个节点上的数据出现了很多个副本的情况,而数据从一个节点复制到另外的节点时需要时间和要求网络畅通的,所以,当P发生时,也就是无法向某个节点复制数据时,这时候你有两个选择:
选择可用性 A(Availability),此时,那个失去联系的节点依然可以向系统提供服务,不过它的数据就不能保证是同步的了(失去了C属性)。
选择一致性C(Consistency),为了保证数据库的一致性,我们必须等待失去联系的节点恢复过来,在这个过程中,那个节点是不允许对外提供服务的,这时候系统处于不可用状态(失去了A属性)。

最常见的例子是读写分离,某个节点负责写入数据,然后将数据同步到其它节点,其它节点提供读取的服务,当两个节点出现通信问题时,你就面临着选择A(继续提供服务,但是数据不保证准确),C(用户处于等待状态,一直等到数据同步完成)。

CP和AP有是什么?有什么区别?相关推荐

  1. 服务注册与发现 — 选择 CP 还是 AP?

    概述 为什么要使用服务发现 假设您正在编写一些代码,这些代码将调用具有 REST API 的服务.为了发出请求,您的代码需要知道服务实例的网络位置(IP 地址和端口).在物理硬件上运行的传统应用程序中 ...

  2. 详解分布式系统核心概念——CAP、CP和AP

    最近研究Sykwalking,当调研 oap如何进行集群部署时发现:skywalking oap 之间本身不能搭建集群,需要一个集群管理器来组建集群,它支持nacos.zookeeper.Kubern ...

  3. zookeeper是cp还是ap

    1.zookeeper是cp还是ap zookeeper保证的是cp,eruka是ap. 准确来说zookeeper保证的是写是强一致性,读是顺序一致性. 2.那么什么是强一致性,什么是顺序一致性 2 ...

  4. nacos的cp和ap原则,服务健康检查

    CP和AP CAP原则:cap理论是针对分布式数据库而言的,它是指在一个分布式系统中,一致性(Consistency,C).可用性(Availability,A).分区容错性(Partition To ...

  5. AUTOSAR CP、AP及其版本

    AUTOSAR CP autosar classic platform,定义了软件架构的3个抽象级别: Application RTE: runtime environment BSW: basic ...

  6. Nacos是两种模式CP与AP Nocos服务注册和配置中心

    zookeeper不支持负载均衡 springBoot 中配置文件的加载是存在优先级顺序的,bootstrap优先级高于application Nacos支持AP与CP模式的切换 C:是所有节点在同一 ...

  7. 一文搞懂注册中心 zookeeper 和 eureka 中的CP和 AP

    作者:胖大星 cnblogs.com/wei57960/p/12260228.html 前言 在分布式架构中往往伴随CAP的理论.因为分布式的架构,不再使用传统的单机架构,多机为了提供可靠服务所以需要 ...

  8. CAP里面的CP和AP

    一.为什么分布式系统要么是CP要么是AP呢? 1.分布式系统:分布式系统是一个硬件或软件组件分布在不同的网络计算机上,彼此之间仅仅通过消息传递进行通信和协调的系统. 2.从分布式系统的定义可知,分布式 ...

  9. CAP理论-分布式系统的基础理论-------CP、AP案例场景分析

    一.前言: CAP理论作为分布式系统的基础理论,它描述的是一个分布式系统在以下三个特性,只能满足其中两个特性,一致性.可用性.分区容错性三者不可兼得: 一致性(Consistency) 可用性(Ava ...

最新文章

  1. 左神讲算法——异或的高级操作(两数交换+经典面试题)
  2. 达观杯_构建模型(二)逻辑回归
  3. mysql-win安装教程,WINDOWS下安装MYSQL教程详解
  4. php伪静态框架,Nginx之php框架常见伪静态rewrite配置
  5. 2018年第九届省赛C/C++A组第4题——第几个幸运数
  6. Qt基于TCP网络程序发包封包抽象
  7. 16-1平衡树源代码
  8. 控件:DataGridView列类型
  9. ubuntu安装teamviewer教程 linux安装teamviewer教程
  10. 「刷新 CTO」微软与 CSDN 的 CTO 转型思想汇
  11. 《重磅 | 机器学习特训营,硅谷导师直播授课,现加入仅需68元!》
  12. vue组件样式scoped
  13. xshell网站打不开
  14. 非线性光纤光学_《Nature》子刊:解决大纵横比光纤中传质不匀的难题!
  15. 文献管理与信息分析2023春课程随堂测验答案
  16. 第四章 Caché JSON 处理数据类型
  17. Chap.18 总结《CL: An Introduction》 (Vyvyan Evans)
  18. 基于matlab的陷波滤波器设计
  19. gitblit中忘记admin密码,怎么办?附详细解决方法和截图
  20. 双系统Linux grub引导,双系统修复ubuntu grub2引导的方法

热门文章

  1. 服务器和电脑主机的区别
  2. gnss、gps、imu、rtk、ins区分及含义
  3. 一份只有做错的人才能做对的作业
  4. 【渝粤教育】国家开放大学2018年秋季 2019T统计学原理 参考试题
  5. android的四种对象引用级别:强、弱、软、虚引用
  6. 第17章- 5~8 钣金实体书架与刚体平台接触分析、材料弹塑性分析(网格控制、刚体接触设置,刚体只能作为接触的目标面、爆炸显示、载荷步设置、残余应力)
  7. Kibana查询语言(KQL)AND、OR匹配,模糊匹配
  8. OJ题——吃货排排坐
  9. TiDB函数和操作符
  10. 孤单是对你最好的惩罚