CAP讲解,BASE讲解

2024-08-22 05:18
文章标签 讲解 base cap

本文主要是介绍CAP讲解,BASE讲解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

CAP:

    C:一致性,在多服务的场景下必须保障各个服务器之间的数据一致性。A:可用性,在分布式或者多服务场景下必须保证服务的可用性,比如需要返回成功和失败。P:分区容错性,必须保证分布式或者多服务场景下服务任何的错误或者数据的丢失都不能影响系统的继续运行。总结: 1.在系统架构的设计的一些场景中,我们只能保证CAP三个情况中的两种,比如在分布式多服务的一些场景和情况中,我们只能优先保证AP或者CP,因为是多服务或者分布式的情况下,我们必须保证P(分区容错性为前提),但是并不是说在分布式系统中一定会一直保持CP或者AP,在某些数据强一致性和可用性的情况下,我们可以使用AP,比如秒杀类的,我们可以对秒杀业务使用单服务运行,多服务备份的情况,其他服务继续使用AP或者CP原则,所以在一个系统的架构中,是可以躲在多个设计原则的,不同的应用场景我们可以采用不同的组合情况来实现,单服务情况下可以直接采用AC原则。2.CAP是忽略延迟性的理想化的模型,比如CP的理论是保证数据的一致性和服务的容错性,但是现实条件中多个服务间是存在网络延迟的,同一个机房也会存在毫秒级的数据不一致性,这种场景是无法满足CP的理论的。3.特殊情况下CA好CP是互补的,比如为了保住AP,服务1和服务2中服务2因为网络或者其他原因导致不可用,服务1继续接收写的请求,这时服务1需要将写入的数据通过日志或者其他方式同步给服务2,当服务2修复启用后快速恢复数据,达到数据一致性,这就是CP。4.在单机服务下,我们可以直接使用AP,因为单服务不存在分区容错性这个说法了。

BASE

      B(Basically Available):基本可用性,指分布式系统出现故障的时候,比如内存不足等情况下我们可以采取保障核心系统可用,非核心的停用,比如在商城系统中,我们为了保障交易系统的可用,可以停掉积分、活动等系统,因为用户可以短时间看不到积分和一些推广活动,这不会影响到客户的正常下单和资金流入。A(Soft State):软状态,就是指在短时间内可以允许不同服务之间的状态不一致,这和CP场景中因为网络传输带来的延迟导致的数据不一致性的场景差不多,也是CP的延伸。E:(Eventually Consistent):最终一致性,就是你可以在短时间内状态不一致,但是最后必须要一致。总结:BASE其实主要是针对CP场景的一种延伸,因为没有完美情况下的CP,所以需要延伸和扩展补充。

这篇关于CAP讲解,BASE讲解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1095346

相关文章

解决升级JDK报错:module java.base does not“opens java.lang.reflect“to unnamed module问题

《解决升级JDK报错:modulejava.basedoesnot“opensjava.lang.reflect“tounnamedmodule问题》SpringBoot启动错误源于Jav... 目录问题描述原因分析解决方案总结问题描述启动sprintboot时报以下错误原因分析编程异js常是由Ja

Unity新手入门学习殿堂级知识详细讲解(图文)

《Unity新手入门学习殿堂级知识详细讲解(图文)》Unity是一款跨平台游戏引擎,支持2D/3D及VR/AR开发,核心功能模块包括图形、音频、物理等,通过可视化编辑器与脚本扩展实现开发,项目结构含A... 目录入门概述什么是 UnityUnity引擎基础认知编辑器核心操作Unity 编辑器项目模式分类工程

MySQL连表查询之笛卡尔积查询的详细过程讲解

《MySQL连表查询之笛卡尔积查询的详细过程讲解》在使用MySQL或任何关系型数据库进行多表查询时,如果连接条件设置不当,就可能发生所谓的笛卡尔积现象,:本文主要介绍MySQL连表查询之笛卡尔积查... 目录一、笛卡尔积的数学本质二、mysql中的实现机制1. 显式语法2. 隐式语法3. 执行原理(以Nes

RabbitMQ消费端单线程与多线程案例讲解

《RabbitMQ消费端单线程与多线程案例讲解》文章解析RabbitMQ消费端单线程与多线程处理机制,说明concurrency控制消费者数量,max-concurrency控制最大线程数,prefe... 目录 一、基础概念详细解释:举个例子:✅ 单消费者 + 单线程消费❌ 单消费者 + 多线程消费❌ 多

从入门到进阶讲解Python自动化Playwright实战指南

《从入门到进阶讲解Python自动化Playwright实战指南》Playwright是针对Python语言的纯自动化工具,它可以通过单个API自动执行Chromium,Firefox和WebKit... 目录Playwright 简介核心优势安装步骤观点与案例结合Playwright 核心功能从零开始学习

嵌入式数据库SQLite 3配置使用讲解

《嵌入式数据库SQLite3配置使用讲解》本文强调嵌入式项目中SQLite3数据库的重要性,因其零配置、轻量级、跨平台及事务处理特性,可保障数据溯源与责任明确,详细讲解安装配置、基础语法及SQLit... 目录0、惨痛教训1、SQLite3环境配置(1)、下载安装SQLite库(2)、解压下载的文件(3)、

Java进程CPU使用率过高排查步骤详细讲解

《Java进程CPU使用率过高排查步骤详细讲解》:本文主要介绍Java进程CPU使用率过高排查的相关资料,针对Java进程CPU使用率高的问题,我们可以遵循以下步骤进行排查和优化,文中通过代码介绍... 目录前言一、初步定位问题1.1 确认进程状态1.2 确定Java进程ID1.3 快速生成线程堆栈二、分析

javascript fetch 用法讲解

《javascriptfetch用法讲解》fetch是一个现代化的JavaScriptAPI,用于发送网络请求并获取资源,它是浏览器提供的全局方法,可以替代传统的XMLHttpRequest,这篇... 目录1. 基本语法1.1 语法1.2 示例:简单 GET 请求2. Response 对象3. 配置请求

Java Stream.reduce()方法操作实际案例讲解

《JavaStream.reduce()方法操作实际案例讲解》reduce是JavaStreamAPI中的一个核心操作,用于将流中的元素组合起来产生单个结果,:本文主要介绍JavaStream.... 目录一、reduce的基本概念1. 什么是reduce操作2. reduce方法的三种形式二、reduce

CSS引入方式和选择符的讲解和运用小结

《CSS引入方式和选择符的讲解和运用小结》CSS即层叠样式表,是一种用于描述网页文档(如HTML或XML)外观和格式的样式表语言,它主要用于将网页内容的呈现(外观)和结构(内容)分离,从而实现... 目录一、前言二、css 是什么三、CSS 引入方式1、行内样式2、内部样式表3、链入外部样式表四、CSS 选