分布式系统中CAP原理[通俗易懂]

分布式系统中CAP原理[通俗易懂]分布式系统CAP原理分布式系统发开虽然有点很多但是并不是完美的,CAP原理就是其中的体现之一。CAP原理:指的是在一个分布式系统中,Consistency(一致性)、Availability(可用性)、Partitontolerance(分区容忍性),三者不可得兼。一致性(C):在分布式系统中的所有数据备份,在同一时刻是否同样的值。简单说就是所有节点在同一时刻的数据完全一致,这就意味着节点越…

大家好,又见面了,我是你们的朋友全栈君。

分布式系统CAP原理

分布式系统发开虽然有点很多但是并不是完美的,CAP原理就是其中的体现之一。
CAP原理:指的是在一个分布式系统中,Consistency(一致性)、Availability(可用性)、Partitontolerance(分区容忍性),三者不可得兼。

一致性(C):在分布式系统中的所有数据备份,在同一时刻是否同样的值。简单说就是所有节点在同一时刻的数据完全一致,这就意味着节点越多数据同步的时候约消耗时间。
比如说分布式数据存储,多台设备需要存储同样的数据,这样一来一旦数据更变那么其他数据库肯定要同步数据,这就意味着我设备越多,我同步的速率也就会越慢,消耗的时长就越多。

可用性(A):负载过大后,集群整体是够还能响应用户正常的读写请求。简单说就是项目不管怎么滴,我系统对于用户请求的响应时间肯定在能接受的范围内的,用户体验不能没有啊。

分区容忍性(P):分区容忍性,就是高可用性,一个节点崩了不会影响其他节点。简单说就是我服务器节点崩了几个没事,只要我有正常的服务器就行了,这样就是说我节点越多就越好了。

CAP不得兼得原理

CAP理论就是说在一个分布式系统中,最多只能实现上面的两点。那我们来分析下。
第一:
拥有AP的时候为什么C不能实现?
在这里插入图片描述
根据上图我们来分析,比如我现在拥有10000个节点,现在要做数据备份,要将10000台设备(p满足了)上都备份上同样的数据,保持数据的一致性(C),我们想象10000台设备数据的同步必然是需要消耗时间,那么我们就没办法实现A,所以要想实现AP那,就不可能保证数据的一致性的。
第二
拥有CP不能为什么不能实现A?
也很好理解,10000台设备,我要保持数据一致性,我就没法保证请求相应时间很短了是吧。
第三
拥有CA为什么不能实现P?
同样的我想要保证数据的一致性,也就是数据的复制,又要保证在合理的请求相应时间内,那么我机器设备不可能很多了,这样就不能满足P了。

依据现在的网络硬件肯定会出现延迟对包的情况,设置个别服务器崩溃,起码得保证系统正常的运行,所以**分区容忍性(P)**是不能缺少的。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/144552.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • gradle教程_Gradle教程

    gradle教程_Gradle教程gradle教程WelcometoGradleTutorial.Inmyearlierposts,welookedintoWhatisGradleandGradleEclipsePlugin.欢迎使用Gradle教程。在我之前的文章中,我们研究了什么是Gradle和GradleEclipse插件。Gradle教程(GradleTutorial)…

  • 模电知识总结(一)

    模电知识总结(一)半导体的基本特性半导体的物理基础:1.掺杂特性2.热敏特性3.光敏特性2.本征半导体:原子排列整齐、晶格无缺陷、纯净的半导体(在热力学温度零度,由于共价键的束缚,价电子能量无法挣脱共价键的束缚,因此晶体中没有自由电子,此时半导体相当于绝缘体。)本征半导体的导电能力很差。(载流子浓度与原子密度相比很少)本征激发(热激发):由热能产生电子-空穴对的现象。随着温度升高,载流子浓度(指数)增加,其电阻率的温度系数是负的,这是半导体导电与金属导电的根本不同点。(相同温度下,锗的载流子浓度大于硅。)

  • Shell脚本基础详解

    Shell脚本基础详解

  • 新人如何入行3D游戏建模

    新人如何入行3D游戏建模所有行业都是一样的,没有什么容易的,只不过这一行是偏向于技术的,一个有好的建模师月薪10k+是很常见的,这个需要有自己刻苦学习的成果。游戏建模前景在游戏模型行业,你基本不用担心找不到工作,因为游戏模型师人才缺口非常大。举个例子:游戏制作公司的人员配比大多数是这样的:比如100人的三维制作组,可能有60人在做模型贴图,10个人在K动画。只要你保证技能在手,一定是抢手的人才。在几年前游戏建模这个行业不仅仅缺人才,甚至连新手都非常稀缺,那个时候公司愿意招聘实习生,培养他们然后给公司干活,但是工资一定不会给开的很

  • 计算机网络 | 一文搞懂什么是TCP/IP协议[通俗易懂]

    什么是TCP/IP协议?计算机与网络设备之间如果要相互通信,双方就必须基于相同的方法.比如如何探测到通信目标.由哪一边先发起通信,使用哪种语言进行通信,怎样结束通信等规则都需要事先确定.不同的硬件,操作系统之间的通信,所有这一切都需要一种规则.而我们就将这种规则称为协议(protocol).也就是说,TCP/IP是互联网相关各类协议族的总称。TCP/IP的分层管理TCP/IP协…

  • 用ajax写注册页面_jquery的ajax请求写法

    用ajax写注册页面_jquery的ajax请求写法<!DOCTYPEhtml><htmllang=”zh-CN”xmlns:th=”http://www.thymeleaf.org”><head><metacharset=”utf-8″/><title>XXXX</title><metaname=”viewport”co…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号