点击上方关注 “终端研发部

设为“星标”,和你一起掌握更多数据库知识

CAP:C(一致性),A(可用性),P(分区容错)

AP

当网络分区出现后,为了保证可用性,系统B可以返回旧值,保证系统的可用性。

结论:违背了一致性C的要求,只满足可用性和分区容错,即AP

CP

当网络分区出现后,为了保证一致性,就必须拒绝请求,否则无法保证一致性。

结论:违背了可用性A的要求,只满足一致性和分区容错,即CP

理论

CAP原则又称CAP定理,指的是在一个分布式系统中,一致性(Consistency)、可用性(Availability)、分区容错性(Partition tolerance),但是CAP 原则指示3个要素最多只能同时实现两点,不可能三者兼顾,由于网络硬件肯定会出现延迟丢包等问题,但是在分布式系统中,我们必须保证部分网络通信问题不会导致整个服务器集群瘫痪,另外即使分成了多个区,当网络故障消除的时候,我们依然可以保证数据一致性,所以我们必须保证分区容错性;

至于剩下的一致性和可用性,我们需要二选一,但是鱼和熊掌不可兼得,假设我们选择一致性,那我们就不能让用户访问无法进行数据同步的机器,毕竟该机器上的数据和其他正常机器上的不一致,但是这样我们就丢弃了可用性;假设我们选择可用性,那我们就可以让用户访问无法进行数据同步的服务器,虽然保证了可用性,但是我们无法保证数据一致性。

具体解释如下:

上面的图少了一部分,这里补上:

动画演示:

可以通过分布式系统中实现一致性的raft算法来了解一下,该算法用动画演示了领导选举、日志复制等过程,这些过程保证在分区错误的情况下依然保证整个集群的数据一致性,其中有一个自旋时间决定节点变成选举人,还有一个心跳时间来发送日志,现在来说一下具体过程,假设当前集群初始启动,之后等到一个自旋时间经过之后,所有人都变成了候选人,之后进行投票,票数最高会成为领导,当然可以会经过多轮选举领导人,领导人在自旋心跳时间之后就会给跟随者发送心跳,然后获得他们的心跳,了解他们是否还活着,如果领导挂掉,那么将再次进行选举,知道选出领导人,当然跟随者死了是不会进行选举的,即使之前挂掉的老领导再回来,它也只能当跟随者了,那些活过来的跟随者会从领导者那里复制日志数据,从而保证集群的数据一致性;如果由于网络原因导致多个节点变成了多个区域,比如之前是5个节点,由于网络原因分成了2个区,那么这两个区独自选择领导,当网络恢复之后,网络故障之前的领导将成为新的领导(如果这个另外还是分区领导的话),它将删除自己还没有使用的日志信息,之后从另外一个分区前领导那里复制日志数据,用来保证集群的数据一致性,这些知识点在上面那个网站中都有演示到,最后再说一点领导选举需要大多数人同意,也就是所有节点的一半以上,比如6个要有一个节点得到4个节点的赞同才能成为领导,即使由于网络故障被分区了也是这样,看的是全部的节点,而不是由于网络故障造成的分区节点,所以在网络故障造成的分区中由于一个分区只有2个节点,而全部有6个节点,所以2个节点的不能选出领导,但是那2个节点之前有一个是老领导,那我们使用的还是是老的领导,如果这2个节点之前没有一个节点是领导,那就不会有领导;

以上是分步演示,还有一个网站可以自己去控制过程,它就是raft算法动画演示,我们可以通过该网站来模拟leader宕机后的领导选举、领导如何保存数据等等过程

AP架构

明显AP结构选择了高可用和分区容错性,此时,那个失去联系的节点依然可以向系统提供服务,不过它的数据就不能保证是同步的了(失去了C属性)。Eureka就是一个AP架构的例子,当Eureka客户端心跳消失的时候,那Eureka服务端就会启动自我保护机制,不会剔除该EurekaClient客户端的服务,依然可以提供需求;

CP结构

CP结构选择的是一致性和分区容错性,如果选择一致性C(Consistency),为了保证数据库的一致性,我们必须等待失去联系的节点恢复过来,在这个过程中,那个节点是不允许对外提供服务的,这时候系统处于不可用状态(失去了A属性)。最好的例子就是zookeeper,如果客户端心跳消失的时候,zookeeper会很快剔除该服务,之后就无法提供需求;

作者:明快de玄米
链接:https://blog.csdn.net/qq_42449963/article/details/105470515
来源:csdn

补充

理论扩展

CAP理论提出就是针对分布式数据库环境的,所以,P这个属性是必须具备的。

在分布式环境下,为了保证系统可用性,通常都采取了复制的方式,避免一个节点损坏,导致系统不可用。那么就出现了每个节点上的数据出现了很多个副本的情况,而数据从一个节点复制到另外的节点时需要时间和要求网络畅通的,所以,当P发生时,也就是无法向某个节点复制数据时,这时候你有两个选择:

选择可用性 A(Availability),此时,那个失去联系的节点依然可以向系统提供服务,不过它的数据就不能保证是同步的了(失去了C属性)。

选择一致性C(Consistency),为了保证数据库的一致性,我们必须等待失去联系的节点恢复过来,在这个过程中,那个节点是不允许对外提供服务的,这时候系统处于不可用状态(失去了A属性)。

场景

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

BAT等大厂Java面试经验总结 想获取 Java大厂面试题学习资料扫下方二维码回复「BAT」就好了回复 【加群】获取github掘金交流群回复 【电子书】获取2020电子书教程回复 【C】获取全套C语言学习知识手册回复 【Java】获取java相关的视频教程和资料回复 【爬虫】获取SpringCloud相关多的学习资料回复 【Python】即可获得Python基础到进阶的学习教程回复 【idea破解】即可获得intellij idea相关的破解教程关注我gitHub掘金,每天发掘一篇好项目,学习技术不迷路!回复 【idea激活】即可获得idea的激活方式
回复 【Java】获取java相关的视频教程和资料
回复 【SpringCloud】获取SpringCloud相关多的学习资料
回复 【python】获取全套0基础Python知识手册
回复 【2020】获取2020java相关面试题教程
回复 【加群】即可加入终端研发部相关的技术交流群为什么HTTPS是安全的
因为BitMap,白白搭进去8台服务器...
《某厂内部SQL大全 》.PDF
字节跳动一面:i++ 是线程安全的吗?
大家好,欢迎加我微信,很高兴认识你!
在华为鸿蒙 OS 上尝鲜,我的第一个“hello world”,起飞!相信自己,没有做不到的,只有想不到的在这里获得的不仅仅是技术!如果喜欢就给个“在看”

什么是AP,什么是CP,什么是CAP?相关推荐

  1. A2 AP AUTOSAR 与 CP AUTOSAR 的特性

    Hello!大家好!欢迎来到<搞一下汽车电子>今天,我们给大家分享的是Adaptive Platform AUTOSAR 专题视频,增加的第二篇内容:A2 自动驾驶 & 域控中间件 ...

  2. CAP理论、AP架构、CP架构

    目录 CAP理论 AP架构 CP结构 CAP理论 CAP原则又称CAP定理,指的是在一个分布式系统中,一致性(Consistency).可用性(Availability).分区容错性(Partitio ...

  3. zookeeper之理论基础

    一.Zookeeper简介 Zookeeper是一个开源的分布式应用程序协调服务器,为分布式系统提供一致性服务,通过采用基于paxos算法的ZAB协议完成.他提供的主要功能包括配置服务.域名服务(服务 ...

  4. 车载软件架构—CP和AP相同与不同

    文章目录 前言 一.两者不同之处 二.两者架构设计原则 总结 前言 AUTOSAR(AUTmotive Open System ARchitecture) 是汽车电子E/E系统发展的一个重要的节点.该 ...

  5. AUTOSAR AP与 CP 有什么差异?

    1标准概况不同 1.1 时间 在2003年AUTOSAR组织刚成立的时候,只有一个AUTOSAR标准,没有AP(Adaptive Platform)与CP(Classic Platform)之分. 在 ...

  6. Nacos 是如何同时实现AP与CP的

    Nacos 是如何同时实现AP与CP的 两种一致性策略如何在nacos中共存 AP实现 CP实现 重要的协议--RAFT nacos是如何实现CP(raft)的 为什么要同时实现CP和AP两套一致性策 ...

  7. 【AutoSAR】 CP 和 AP

    概述 AutoSAR,全称为Automotive Open System Architecture(汽车开放系统架构).是由全球各家汽车制造商.零部件供应商以及各种研究.服务机构共同参与的一种汽车电子 ...

  8. Nacos中AP和CP模式如何切换

    CAP理论 这个定理的内容是指的是在一个分布式系统中.Consistency(一致性). Availability(可用性).Partition tolerance(分区容错性),三者不可得兼. 一致 ...

  9. Nacod服务注册与发现(AP架构)、心跳检查机制

    文章目录 1. Nacos核心功能点 2. 服务注册 ①: 客户端向Nacos服务端发起注册请求 ②: Nacos服务端保存服务实例到注册表中 3. 服务发现 4. Nacos如何处理服务事件变动? ...

  10. Autosar AP – 概要

    未来E/E架构的发展有如下需求: 互联:连接车辆需要高带宽的动态数据连接,以进行故障管理.路边基础设施互动.实时更新前方道路状况的 ADAS 系统.空中软件更新OTA等. 自动驾驶:自动驾驶和辅助系统 ...

最新文章

  1. 【目标检测】yolo系列:从yolov1到yolov5之YOLOv3详解及复现
  2. 【c语言】蓝桥杯算法提高 算术运算
  3. 电脑达人教你怎么解决Win7系统盘渐渐变小的问题
  4. 快速搭建实验环境:使用 Terraform 部署 Proxmox 虚拟机
  5. java入栈_java中代码块的执行,也会有入栈的步骤吗?
  6. 通俗易懂!视觉slam第二部分——salm过程简介
  7. Servlet教程第4讲笔记
  8. clickhouse: WSL下常见问题、常见用法和A股数据实践
  9. 计算机地址聚合,cidr怎么算?cidr地址聚合快速算法
  10. 基于成熟网管平台的网管软件开发模式
  11. android 手指滑动顺时针逆时针判断
  12. windows,远程开机,远程唤醒(WOL,Wake-on-LAN)
  13. 应聘总经理的答卷,供大家打分!(一)
  14. 如何将excel转换成word文档图文教程
  15. Python3-爬虫~selenium\phantomjs\爬取XX网页电影过程中向下滚动网页问题
  16. 疫情下失业开发即时通讯软件(仿微信)-优化服务器端吞吐量
  17. 打印六芒星_java
  18. 【强烈推荐收藏】坚持3个月爆肝华为机试108题C++全解(适合新手入门,就业必刷套题)
  19. 大数据技术之 Flume
  20. Python编写程序计算如下的分段函数

热门文章

  1. 【王道考研】操作系统 笔记 第二章上 进程调度
  2. 长亭科技崔勤:如何打造一个“安全巡检”神器 | 深度
  3. php 正态分布数据描述,正态分布-统计百科- 人大经济论坛-经管百科
  4. Linux中的nl命令
  5. 计算机的内存的作用是什么,电脑内存的作用是什么?
  6. latex里图片大小如何调整_调整LaTeX文档页面的大小
  7. js怎么实现对html代码加密解密,JS实现Base64加密解密
  8. Highlight_Matching_Pair问题解决
  9. 值得收藏的5个C++网站
  10. 【leetcode Database】175.Combine Two Tables