【分布式】CAP理论及其应用
CAP Theorem
CAP
指的就是 "consistency 一致性","availability 可用性" "partition-tolerance 分区容错性".consistency
: 一致性是指写操作后的读操作可以读取到最新的数据状态,当数据分布在多个节点上,从任意结点读取到的数据都是最新的状态。
特点:1.由于数据同步过程,写操作的响应存在一定的延迟
2.为了保证数据一致性会对资源进行暂时锁定,待数据同步完成释放锁资源
3.如果请求数据同步失败的结点则会返回错误信息,一定不会返回旧数据。availability
: 可用性是指任何事务操作都可以得到响应结果,且不会出现响应超时或响应错误。
特点:1.所有请求都有响应,且不会出现响应超时或响应错误。partition-tolerance
:网络中断等问题发生后系统能正常工作,提供服务,保证一致性和可用性,不同分区之间数据同步时不影响分区数据的读写操作。一般来说,分区容错无法避免,因此可以认为 CAP 的 P 总是成立。所以在CAP原则里面,分区容错性是必须要有的
特点:1.分区容忍性分是布式系统具备的基本能力。
- 一致性、可用性和分区容错性不可能同时全部满足。最多只能满足其中两个。一致性和可用性是相互矛盾的,一般只能满足其中之一。
CAP组合方式
AP
:牺牲了数据一致性,追求可用性和分区容错性。可能导致全局数据不一致。客户端发出请求之后,为了保证可用性,得到的响应可能是旧的数据,因为数据的同步需要时间,但在某些情况下旧数据也是可以接受的,通常实现AP都会保证最终一致性。比如订单退款操作,用户申请退款以后,得到信息”今日退款成功,明日账户到账“,只要用户接受在一定时间内到账即可。AP的应用也比较广泛,主要好处是可以保证数据传递的时效性,提高用户体验。AP是最常见的模型。CP
: 放弃可用性,追求一致性和分区容错性。属于强一致性。等待数据同步完才能正常访问服务,保证用户得到的数据一定是最新的,否则不返回数据。一旦发生网络故障或者消息丢失等情况,就要牺牲用户的体验。举个例子,银行跨行转账时,一次转账需要等待双方银行都完成整个事务的时候才算完成,这种应用场景常见于金融系统。应用有Redis、zookeeper等。CA
:放弃了分区容错性,保证了一致性和可用性。这就不属于一个严格的分布式系统了,任何一个分区服务器出故障,都可能导致整个系统的崩溃。关系型数据库满足CA,比如Oracle、MySQL。以上所写的”牺牲、放弃“等并不是表示完全怕抛弃某一个特性,而是表示降低对该特性的要求,提高另外对两个特性的要求
CAP理论在数据库领域的应用
附录
提供一篇HP的关于分布式的论文以供参考
【分布式】CAP理论及其应用的更多相关文章
- 三分钟分布式CAP理论
分布式系统架构理论,定义了三种指标,理论说我们最多只能满足两个. ## 分布式系统 首先我们这个理论所说的分布式系统,是指系统内会共享数据,互相有连接有交互,才能完成系统功能的的分布式系统.而这个理论 ...
- 分布式CAP理论
分布式CAP理论 来自wiki: 在理论计算机科学中,CAP定理(CAP theorem),又被称作布鲁尔定理(Brewer's theorem),它指出对于一个分布式计算系统来说,不可能同时满足以下 ...
- 分布式CAP理论介绍:一致性(Consistency),可用性(Availability),容忍网络分区(Partition tolerance)
在理论计算机科学中,CAP定理(CAP theorem),又被称作布鲁尔定理(Brewer's theorem),它指出对于一个分布式计算系统来说,不可能同时满足以下三点: 一致性(Consisten ...
- 分布式零基础之--分布式CAP理论
研究到分布式系统CAP理论,记录下来下回详细分析它: CAP是指三个单词的简称 C: 一致性(Consistence) 所有节点访问的都是同一份最新的数据副本. A: 可用性(Availability ...
- 分布式系统及CAP理论
一.集中式系统 在学习分布式之前,先了解一下与之相对应的集中式系统是什么样的. 集中式系统用一句话概括就是:一个主机带多个终端.终端没有数据处理能力,仅负责数据的录入和输出.而运算.存储等全部在主机上 ...
- 从分布式一致性谈到CAP理论、BASE理论
问题的提出 在计算机科学领域,分布式一致性是一个相当重要且被广泛探索与论证问题,首先来看三种业务场景. 1.火车站售票 假如说我们的终端用户是一位经常坐火车的旅行家,通常他是去车站的售票处购买车票,然 ...
- 【转】分布式理论-CAP理论
一 CAP理论简述 CAP (Consistency, Availability, Partition Tolerance,) 理论是NoSQL数据库管理系统构建的基础. 强一致性:等同于所 ...
- 分布式领域CAP理论
分布式领域CAP理论,Consistency(一致性), 数据一致更新,所有数据变动都是同步的Availability(可用性), 好的响应性能Partition tolerance(分区容错性) 可 ...
- 分布式 基本理论 CAP
谈及分布式,必然谈到 CAP, CAP 已经是被说烂了的一个 话题, 绕不开, 逃不掉. 而且, 理解起来 会有些吃力. 分布式的CAP理论告诉我们 “任何一个分布式系统都无法同时满足 一致性(Co ...
- CAP理论与分布式事务解决方案
微服务系统所设计的系统是分布式系统.分布式系统有一个著名的CAP理论,即同时满足"一致性""可用性"和"分区容错"是一件不可能的事.CAP理 ...
随机推荐
- nignx反向代理web服务器的配置与使用
一.为什么要用nignx反向代理 1.负载均衡 当一台服务器的单位时间内的访问量越大时,服务器压力就越大,大到超过自身承受能力时,服务器就会崩溃.为了避免服务器崩溃,让用户有更好的体验,我们通过负载均 ...
- Web应用漏洞-NGINX各类请求头缺失对应配置
前言 随着越来越多的网络访问通过WEB界面进行操作,WEB安全已经成为互联网安全的一个热点,基于WEB的攻击广为流行,SQL注入.跨站脚本等WEB应用层漏洞的存在使得网站沦陷.页面篡改.网页挂马等攻击 ...
- GO语言面向对象01---封装属性与创建对象的方法与工厂模式
package main import "fmt" /* 面向过程编程:调度大量的变量.函数 ---------- 面向对象编程(OOP=Object Oriented Progr ...
- Mobileye_EyeQ4功能和性能
Mobileye_EyeQ4功能和性能 一.硬件平台 图丨 Mobileye EyeQ4 架构(Mobileye EyeQ4使用了多MIPS处理器) 为确保 L3 级别以上的自动驾驶汽车市场,Mobi ...
- CVPR2020最新论文扫描盘点(上)
CVPR2020最新论文扫描盘点(上) 最近计算机视觉三大顶会之一CVPR2020接收结果已经公布,一共有1470篇论文被接收,接收率为22%,相比去年降低3个百分点,竞争越来越激烈.这里整理来自Tw ...
- CUDA 8混合精度编程
CUDA 8混合精度编程 Mixed-Precision Programming with CUDA 8 论文地址:https://devblogs.nvidia.com/mixed-precisio ...
- Java真的是白天鹅
前言 我最近越来越真切的感受到,Java真的是白天鹅. 这真的是一种羡慕嫉妒恨的感受. 今天和一个Java技术Leader聊天,我告诉他敏捷开发是以人为本,他居然跟我说敏捷开发在行业内有规范,规范是死 ...
- 使用Vue写一个九九乘法表
Vue.js是一套构建用户界面的渐进式框架.与其他重量级框架不同的是,Vue 采用自底向上增量开发的设计. 下面是在Vue 测试实例 - 菜鸟教程(runoob.com)使用Vue写的一个九九乘法表, ...
- pycharm在虚拟机跑深度学习Mac
1.在PyCharm里配置部署环境 打开PyCharmTools > Deployment > Configuration, 新建一个SFTP服务器,名字自己取: 输入如下图配置,注意这里 ...
- 十六、.net core(.NET 6)搭建基于Redis的Hangfire定时器
搭建基于Redis的Hangfire定时器 Hangfire的定时配置信息会自动生成在指定到数据库内,包括关系型数据库或非关系型数据库内.目前为止,它在Redis.Oracle上面,可以支持最短15秒 ...