前有CAP理论,后有BASE理论,分布式系统理论基石

news2024/10/5 16:21:54

🧑‍💻作者名称:DaenCode
🎤作者简介:CSDN实力新星,后端开发两年经验,曾担任甲方技术代表,业余独自创办智源恩创网络科技工作室。会点点Java相关技术栈、帆软报表、低代码平台快速开发。技术尚浅,闭关学习中······
😎人生感悟:尝尽人生百味,方知世间冷暖。


专栏推荐

  • 专门为Redis入门打造的专栏,包含Redis基础知识、基础命令、五大数据类型实战场景、key删除策略、内存淘汰机制、持久化机制、哨兵模式、主从复制、分布式锁等等内容。链接>>>>>>>>>《Redis从头学》
  • SpringBoot实战相关专栏,包含SpringBoot过滤器、拦截器、AOP实现日志、整合Freemaker、整合Redis等等实战相关内容,多篇文章登入全站热榜、领域热榜、被技术社区收录。链接>>>>>>《SpringBoot实战》

文章目录

  • 专栏推荐
  • 🌟前言
  • 🌟分布式系统
  • 🌟CAP理论
  • 🌟BASE理论
  • 🌟写在最后

🌟前言

最近学习分布式系统,其中有两大理论分别是CAP理论和BASE理论,那么到底该如何理解它们呢?本文就揭晓一下。


🌟分布式系统

在说CAP理论和BASE理论之前,先来简单概括一下分布式系统是什么?分布式系统就是多个计算机或者多个节点通过网络连接起来的一个系统。


🌟CAP理论

首先来介绍一下CAP理论,它是由国外某个大佬提出来的,具体是谁我也忘记了。这个理论最早在2000年提出,最终在2002年被证明。大致意思就是CAP理论中的这三个字母它在分布式系统中是无法被同时满足的。三个字母的具体意思见下方:

  • C(Consistency):一致性。这个一致性就是用户在访问分布式的任意节点中的数据时,都能够访问到最新的结果。
  • A(Availability):可用性。这个可用性就是用户能够正常的访问到系统中的数据。
  • P(Partition Tolerance):分区容错性。这个分区容错性指的是系统即使有节点故障或者网络故障的情况下,它也是可以运行的。

这个根据这个CAP理论来分析,分布式系统的设计方案有以下三种,可以参照下方画的草图:

  1. CA:一致性+可用性的组合。这个组合扔掉了P,这个无法保证系统的扩展性和容错性是违背分布式系统设计的初衷的。
  2. CP:一致性+分区容错性的组合。这个组合扔掉了A:可用性。这个适用于强一致性的场景,对于请求可以有部分延迟。
  3. AP:可用性+分区容错性的组合。这个适用于要求可用性,但是对于一致性不高的场景,数据最终能够达到一致性即可。

在这里插入图片描述


🌟BASE理论

BASE理论可以理解为CAP理论的权衡结果。具体解释见下方:

  • BA(Base Aviliable):基本可用。对可用性的权衡。就是功能不影响正常的使用,允许网络存在一定的时间延迟。比如说静态资源的加载、兜底数据的返回。
  • S(Soft state):软状态。允许系统的数据非强一致性,但是数据最终能够达到一致性。可以理解为数据存在一个中途状态。
  • E(Eventually consisten):最终一致性。系统会逐渐将数据的不一致性解决,最终达到一致性状态
    在这里插入图片描述

🌟写在最后

有关于前有CAP理论,后有BASE理论,分布式系统理论基石到此就结束了。感谢大家的阅读,希望大家在评论区对此部分内容散发讨论,便于学到更多的知识。

有更好的理解方法,欢迎大家指出!!!


请添加图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1038953.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

物联网如何改变智能家居技术?

物联网(IoT)已经在智能家居技术方面产生了深远的影响,其通过将各种设备、传感器和家居设备连接到互联网,实现了智能家居技术的创新和改进。 物联网(IoT)已经在智能家居技术方面产生了深远的影响,其通过将各种设备、传…

【手动实现nn.Linear 】

线性变换参数可视化图 class LinearLayer(nn.Module):def __init__(self, input_dim, output_dim):super(LinearLayer, self).__init__()self.weights nn.Parameter(torch.Tensor(output_dim, input_dim))self.bias nn.Parameter(torch.Tensor(output_dim))# 初始化权重和偏…

codesys自由编码器

1用于位置处理。 2它有个变量: SMC_FreeEncoder.diEncoderPosition 【DINT】 SMC_FreeEncoder_1.diEncoderPosition : GVL.电位器1; SMC_FreeEncoder.diEncoderPosition:hsi_cnt.diCurCountValue; //编码器位置 默认一圈是360.00 给它赋值&#x…

【AI画图】Stable Diffusion WebUI

💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:kuan 的首页,持续学…

机器学习西瓜书+南瓜书吃瓜教程学习笔记第三章(二)

南瓜书视频链接 以下是我的学习笔记 1、多元线性回归 首先跟着视频推了一遍,真的厉害,很清晰怎么来的 多元线性回归与一元线性回归同理利用最小二乘法求w和b。 这里我们讨论了如何使用线性模型进行回归学习,但若要做的是分类任务呢&#…

dhclient命令 – 动态获取或释放IP地址

参考链接:https://www.linuxcool.com/dhclient # dhclient命令 – 动态获取或释放IP地址 原文链接:https://www.linuxcool.com/dhclient

【计算机操作系统慕课版】第一章课后习题

课后习题目录: 一、简答题 1.在计算机系统上配置OS的目标是什么?作用表现在哪几个方面? 2.试说明OS与硬件、其他系统软件以及用户之间的关系。 3.试说明推动OS发展的主要动力是什么。 4.在OS中,何谓脱机I/O方式和联机I/O方式…

CVE-2023-42442:JumpServer堡垒机会话回放未授权访问漏洞复现

JumpServer堡垒机会话回放未授权访问漏洞(CVE-2023-42442) 0x01 前言 免责声明:请勿利用文章内的相关技术从事非法测试,由于传播、利用此文所提供的信息或者工具而造成的任何直接或者间接的后果及损失,均由使用者本人…

【系统架构】软件可靠性基础知识

导读:本文整理关于软件可靠性基础知识构建系统架构知识体系。完整和扎实的系统架构知识体系是作为架构设计的理论支撑,基于大量项目实践经验基础上,不断加深理论体系的理解,从而能够创造新解决系统相关问题。 目录 1、软件可靠性…

解决VSCODE 终端中显示中文乱码的问题

这里默认是UTF8 修改为GBK 选择通过编码保存 搜索GBK并选择即可 正常显示

【JVM】类加载子系统——自问自答

1、类加载的过程: java的类加载过程,是把字节码文件(.class file) 转换到JVM中运行时数据区内的过程。 类加载的过程由 类加载器子系统完成(Class Loader). 字节码文件可以像我们日常开发时在特定文件夹路径下的jar包里,也可以从网络中获取…

【RocketMQ】(七)事务实现原理

RocketMQ事务的使用场景 单体架构下的事务 在单体系统的开发过程中,假如某个场景下需要对数据库的多张表进行操作,为了保证数据的一致性,一般会使用事务,将所有的操作全部提交或者在出错的时候全部回滚。以创建订单为例&#xf…

6.5 图的遍历

前言: 主要内容: 这段文字描述的是图的遍历。图的遍历与树的遍历有些相似,都是从某个点开始,按照一定的规则遍历其他的点,但是图的遍历更加复杂,因为图中存在循环和回路,这意味着可能会多次访…

JavaWeb开发-09-MyBatis

官网:https://mybatis.org/mybatis-3/zh/index.html 一.Mybatis入门 1.快速入门 2.JDBC介绍 3.数据库连接池 官方地址:https://github.com/alibaba/druid/tree/master/druid-spring-boot-starter 4.lombok 二.Mybatis基础增删改查 1.准备 2.删除 3.新增…

AT24C02芯片

AT24C02简介: AT24C01/02/04/08/16...是一个 1K/2K/4K/8K/16K 位串行 CMOS内部有9个字节; 该器件通过 I2C 总线接口进行 操作,它有一个专门的写保护功能; 基于51 他有这个芯片操作 时序: AT24C02软件编程: …

darknet yolov3 模型训练步骤整理

1. 把需要训练的图片拷贝到 D:\模型训练\darknet-master\build\darknet\x64\data\VOCdevkit\VOC2012\JPEGImage 2. 执行imageName.py 文件,重命名JPEGImage下的图片。 D:\模型训练\darknet-master\build\darknet\x64\data\VOCdevkit\VOC2012\imageName.py 3. 用…

Termius 8 for Mac(多协议服务器连接软件)

Termius是一款远程访问和管理工具,旨在帮助用户轻松地远程连接到各种服务器和设备。它适用于多种操作系统,包括Windows、macOS、Linux和移动设备。 该软件提供了一个直观的界面,使用户可以通过SSH、Telnet和Mosh等协议连接到远程设备。它还支…

微表情识别API + c++并发服务器系统

微表情识别API系统 该项目只开源前后端程序,模型不开源 地址:https://github.com/lin-lai/-API- 更新功能 4.1版本 改用epoll实现IO多路复用并发服务器去除标志位设定—正在考虑用协议实现 项目介绍 本项目用于检测并识别视频中人脸的微表情 目标任…

【插件】页面引导库driver.js:

文章目录 一、效果图:二、实现思路:三、实现代码:【1】Driver.js 的技术特性【2】安装依赖【3】代码实现【4】 配置相关参数 一、效果图: 二、实现思路: 【官网】https://driverjs.com/docs/installation 【npm】https://www.npmjs.com/package/driver.js 【案例】改造driver.j…

用Python在XML和Excel表格之间实现互转

XML是一种超文本标记语言和文件格式,具有可自定义标签,易于扩展,便于编辑,传输便捷等优点。XML已成为应用数据交换的常用方式。虽然XML格式易于传输和开发者操作,但对于普通用户来说,数据以xls或xlsx的形式…