当前位置: 首页 > article >正文

一篇文章玩转CAP原理

CAP 原理是分布式系统设计的核心理论之一,揭示了系统设计中的 根本性权衡


一、CAP 的定义

CAP 由三个核心属性组成,任何分布式系统最多只能同时满足其中两个

  1. 一致性(Consistency)

    • 所有节点在同一时刻看到的数据完全一致(强一致性)。
    • 例如:写入操作成功后,所有后续读操作必须返回最新值。
  2. 可用性(Availability)

    • 每个非故障节点必须对请求给出响应(不保证是最新数据)。
    • 例如:即使部分节点故障,系统仍能处理读写请求。
  3. 分区容忍性(Partition Tolerance)

    • 系统在网络分区(节点间通信中断)时仍能继续运行。
    • 例如:两个机房之间的网络断开后,系统仍能提供服务。

二、CAP 的权衡

1. CA 系统(放弃 P)
  • 特点:优先保证一致性和可用性,但无法容忍网络分区。
  • 现实意义:单机数据库(如 MySQL 主从架构)本质是 CA,但严格来说分布式系统中无法放弃 P(网络分区必然存在)。
  • 适用场景:传统单数据中心架构(假设网络绝对可靠)。
2. CP 系统(放弃 A)
  • 特点:在网络分区时,牺牲可用性以保持一致性。
  • 典型系统
    • ZooKeeper:通过 ZAB 协议保证强一致性,分区时拒绝写入。
    • etcd:基于 Raft 协议,分区时少数派节点不可用。
  • 适用场景:金融交易、分布式锁等对一致性要求极高的场景。
3. AP 系统(放弃 C)
  • 特点:在网络分区时,牺牲一致性以保持可用性。
  • 典型系统
    • Redis 集群:主从异步复制,分区时可能返回旧数据。
    • Cassandra:最终一致性模型,允许短暂数据不一致。
  • 适用场景:社交网络、实时推荐等容忍最终一致性的场景。

三、CAP 的常见误解

误解 1:CAP 是“三选二”
  • 真相:CAP 的取舍仅在发生网络分区时触发。在无分区时,系统可同时满足 CA。
  • 示例:Redis 集群在无分区时是 CA,分区时变为 AP。
误解 2:一致性只能是强一致性
  • 真相:CAP 中的 C 是强一致性,但实际系统可放宽一致性(如最终一致性)。
  • 示例:DynamoDB 允许配置读写一致性级别(强一致或最终一致)。
误解 3:分区容忍性可被忽略
  • 真相:分布式系统必须设计分区容忍性(P),因为网络分区是必然发生的。
  • 结论:实际分布式系统本质在 CP 或 AP 之间选择。

四、CAP 的演进:PACELC 理论

在 CAP 基础上进一步细化,提出 PACELC

  1. 分区场景(Partition, P):选择 A(可用性)或 C(一致性)。
  2. 无分区场景(Else, E):选择 L(低延迟)或 C(一致性)。
    • 示例
      • MongoDB:分区时选 AP(优先可用性),无分区时选 CP(强一致性)。
      • DynamoDB:允许配置无分区时的读写一致性。

五、CAP 的实际应用

案例 1:银行转账系统(CP)
  • 要求强一致性,转账操作必须保证所有节点数据一致,即使停机维护也要拒绝请求(牺牲可用性)。
案例 2:社交媒体点赞(AP)
  • 允许短暂计数不一致,优先保证用户能正常点赞(最终一致性可接受)。
案例 3:分布式缓存(AP)
  • 如 Redis 集群,允许缓存数据短暂不一致,但确保高可用性和低延迟。

六、CAP 的设计启示

  1. 明确业务优先级
    • 金融系统选 CP,社交平台选 AP。
  2. 分层设计
    • 混合使用 CP 和 AP 组件(如核心交易用 CP,日志分析用 AP)。
  3. 最终一致性的补偿
    • 通过异步校验、幂等操作等手段弥补 AP 系统的不足。
  4. 容灾与降级
    • 网络分区时,通过降级策略保证核心功能可用。

七、🐮🐎

  • CAP 的本质:分布式系统的设计必须直面网络分区的现实,并在一致性和可用性之间权衡。
  • CAP 不是约束:而是指导工程师根据业务需求做出合理取舍的工具。
  • 现代系统的灵活性:通过最终一致性、多级缓存、异步复制等技术,可在不同场景下逼近“三者兼顾”。

你想要的我全都有:https://pan.q删掉憨子uark.cn/s/75a5a07b45a2

在这里插入图片描述

相关文章:

一篇文章玩转CAP原理

CAP 原理是分布式系统设计的核心理论之一,揭示了系统设计中的 根本性权衡。 一、CAP 的定义 CAP 由三个核心属性组成,任何分布式系统最多只能同时满足其中两个: 一致性(Consistency) 所有节点在同一时刻看到的数据完全…...

Vue-收集表单信息

收集表单信息 Input label for 和 input id 关联, 点击账号标签 也能聚焦 input 代码 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" /><title>表单数据</title><!-- 引入Vue --><scrip…...

私服 nexus 之间迁移 npm 仓库

本文介绍如何将一个 Nexus 特定仓库中的 npm 包内容迁移到另一个 Nexus 特定仓库。此过程适用于需要重构仓库结构或合并仓库的场景。 迁移脚本 以下是完整的迁移脚本&#xff0c;它会自动完成以下操作&#xff1a; 从源仓库获取所有 npm 包列表下载每个包的 .tgz 文件解压并…...

微服务及容器化设计--可扩展的架构设计

引言 在当今快速发展的技术环境中&#xff0c;企业需要构建能够适应变化、支持快速迭代且可靠的软件系统。传统的单体应用架构在面对高并发、大规模部署和复杂业务逻辑时往往力不从心。微服务架构结合容器化技术应运而生&#xff0c;成为现代可扩展系统设计的主流选择。本文将…...

vscode开发stm32,main.c文件中出现很多报错影响开发解决日志

本质上为 .vscode/c_cpp_properties.json文件和Makefile文件中冲突&#xff0c;两者没有同步。 将makefile文件中的内容同步过来即可&#xff0c;下面给出一个json文件的模板&#xff0c;每个人的情况不同&#xff0c;针对性修改即可 {"configurations": [{"na…...

嵌入式鸿蒙系统中水平和垂直以及图片调用方法

利用openharmony操作的具体现象: 第一:Column 作用:沿垂直方向布局的容器。 第二:常用接口 Column(value?: {space?: string | number}) 参数: 参数名参数类型必填参数描述spacestring | number否纵向布局元素垂直方向间距。 从API version 9开始,space为负数或者ju…...

【海康USB相机被HALCON助手连接过后,MVS显示无法连接故障。】

在Halcon里使用助手调用海康USB相机时&#xff0c;如果这个界面点击了【是】 那么恭喜你&#xff0c;相机只能被HALCON调用使用&#xff0c;使用MVS或者海康开发库&#xff0c;将查找不到相机 解决方式&#xff1a; 右键桌面【此电脑】图标 ->选择【管理】 ->选择【设备…...

面试大厂Java:从Spring Boot到微服务架构

面试大厂Java&#xff1a;从Spring Boot到微服务架构 在一个阳光明媚的下午&#xff0c;谢飞机来到了某知名互联网大厂的面试现场&#xff0c;迎接他的是一位严肃的面试官。 第一轮提问&#xff1a; 面试官&#xff1a; 谢飞机&#xff0c;请你简单介绍一下Spring Boot的核心…...

2025年电气工程与轨道交通国际会议:绿色能源与智能交通的创新之路

2025年电气工程与轨道交通国际会议&#xff08;ICEERT 2025&#xff09;是一场电气工程与轨道交通领域的国际盛会&#xff0c;将于2025年在武汉隆重召开。此次会议汇聚了全球顶尖的专家学者和行业精英&#xff0c;共同探讨电气工程与轨道交通的最新研究成果和技术趋势。会议将围…...

macOS 安装 Grafana + Prometheus + Node Exporter

macOS 安装指南&#xff1a;Grafana Prometheus Node Exporter 目录简介&#x1f680; 快速开始 安装 Homebrew1. 安装 Homebrew2. 更新 Homebrew 安装 Node Exporter使用 Homebrew 安装验证 Node Exporter 安装 Prometheus使用 Homebrew 安装验证安装 安装 Grafana使用 Home…...

WPF log4net用法

WPF log4net用法 一、在工程中管理NuGet程序包&#xff0c;找到log4net&#xff0c;点击安装&#xff0c;如下图已成功安装&#xff1b; 二、在工程中右键添加新建项&#xff0c;选择应用程序配置文件&#xff08;后缀为.config&#xff09;,然后设置名称&#xff0c;这里设置…...

数字孪生数据监控如何提升汽车零部件工厂产品质量

一、汽车零部件工厂的质量挑战 汽车零部件作为汽车制造的基础&#xff0c;其质量直接关系到整车的性能、可靠性和安全性。在传统的汽车零部件生产过程中&#xff0c;质量问题往往难以在早期阶段被发现和解决&#xff0c;导致生产效率低下、生产成本上升&#xff0c;甚至影响到…...

web自动化-Selenium、Playwright、Robot Framework等自动化框架使用场景优劣对比

Web 自动化测试框架根据不同的技术栈和应用场景可分为多种类型&#xff0c;以下是常见的框架及其特点、适用场景&#xff1a; 一、主流框架分类 1. Selenium 生态&#xff08;Python/Java/C#/JavaScript&#xff09; 核心组件&#xff1a; WebDriver&#xff1a;操作浏览器的…...

使用 Akamai 分布式云与 CDN 保障视频供稿传输安全

作者简介&#xff1a;David Eisenbacher 是 EZDRM 公司的首席执行官兼联合创始人&#xff0c;该公司是首家提供 "DRM 即服务" 的企业。作为 CEO&#xff0c;David 始终秉持为企业确立的使命&#xff1a;为视频服务商提供简洁有效的数字版权管理方案&#xff0c;助力其…...

vue发版html 生成打包到docker镜像进行发版

将Vue项目打包成Docker镜像部署主要分为以下几个步骤&#xff1a; 1. Vue项目打包‌ 执行npm run build生成dist文件夹&#xff0c;包含静态资源文件 注意检查index.html中资源引用路径是否正确&#xff08;避免绝对路径问题&#xff09; 2. 编写Dockerfile Copy Code FROM…...

python uv包管理器使用

官方文档&#xff1a;uv官方文档 注&#xff1a;uv安装不依赖python。 使用&#xff1a; python版本管理 # 查看已安装的python列表 uv python list # 安装特定版本 uv python install 3.12 # 指定项目使用的python版本 uv python pin <version># 使用指定版本运行脚本…...

贪心算法实战3

文章目录 前言区间问题跳跃游戏跳跃游戏II用最少数量的箭引爆气球无重叠区间划分字母区间合并区间 最大子序和加油站监控二叉树 前言 今天继续带大家进行贪心算法的实战篇3&#xff0c;本章注意来解答一些运用贪心算法的比较难的问题&#xff0c;大家好好体会&#xff0c;怎么…...

linux、docker、git相关操作

1 linux 1.1解压缩 1.1.1 zip zip xxx.zip file 把file压缩成xxx.zip -r 递归压缩&#xff1a; zip -r example_new.zip 示例集 # 新建压缩包并命名为 example_new.zip zip -r xxx.zip file1 file2 dir1 将多个文件目录压成zip包 unzip file.zip -d target_dir #把file.zip解…...

实测,大模型谁更懂数据可视化?

大家好&#xff0c;我是 Ai 学习的老章 看论文时&#xff0c;经常看到漂亮的图表&#xff0c;很多不知道是用什么工具绘制的&#xff0c;或者很想复刻类似图表。 实测&#xff0c;大模型 LaTeX 公式识别&#xff0c;出乎预料 前文&#xff0c;我用 Kimi、Qwen-3-235B-A22B、…...

小程序32-简易双向数据绑定

在WXML中&#xff0c;普通属性的绑定是单向的&#xff0c;例如:<input value"{{value}}" /> 如果希望用户输入数据的同时改变data中的数据&#xff0c;可以借助简易双向绑定机制。在对应属性之前添加model:前缀即可: 例如<input model:value"{{value}…...

jenkins报错java.lang.OutOfMemoryError: Java heap space

报错信息 2025-05-27 09:17:16.2340000 [id38] WARNING j.u.ErrorLoggingScheduledThreadPoolExecutor#afterExecute: failure in task not wrapped in SafeTimerTask java.lang.OutOfMemoryError: Java heap spaceat java.base/java.lang.StringUTF16.compress(StringUTF16.j…...

leetcode669.修剪二叉搜索树:递归法利用有序性精准剪枝

一、题目深度解析与BST特性应用 题目描述 给定一棵二叉搜索树&#xff08;BST&#xff09;和一个值区间[low, high]&#xff0c;修剪BST使得所有节点的值都落在该区间内。修剪后的树必须保持BST的性质&#xff0c;且不能改变原有节点的相对位置关系。 BST的核心特性应用 二…...

Spring Boot 中 @RequestParam 和 @RequestPart 的区别详解(含实际项目案例)

Spring Boot 中 RequestParam 和 RequestPart 的区别详解&#xff08;含实际项目案例&#xff09; 在日常的 Spring Boot 开发中&#xff0c;我们经常会遇到表单提交、文件上传、JSON 参数绑定等需求。而在处理这类请求时&#xff0c;两个常见的注解——RequestParam 和 Reque…...

Linux入门(十一)进程管理

Linux 中每个执行的程序都称为一个进程&#xff0c;每个进程都分配一个ID号&#xff08;PID&#xff09; 每个进程都可能以两种方式存在&#xff0c;前台&#xff08;屏幕上可以操作的&#xff09;和后台&#xff08;屏幕上无法看到的&#xff09;&#xff0c;一般系统的服务都…...

【课堂笔记】EM算法

文章目录 背景极大似然估计隐变量高斯混合模型EM算法合理性分析相关好文章背景 EM算法(期望最大化算法,Expectation-Maximization Algorithm)是一种迭代优化算法,用于在含有隐变量的概率模型中估计最大似然参数。   这是概括性的定义,下面我会解释其中的名词并用具体例子…...

怎样将win11+ubuntu双系统的ubuntu从机械硬盘迁移至固态硬盘(1)

将 Ubuntu 从机械硬盘迁移到固态硬盘是一个涉及多个步骤的过程。以下是一个基本的迁移指南&#xff1a; 1. 前期准备 1.1 备份数据&#xff1a; 确保你已备份数据&#xff0c;以防止在迁移过程中出现意外导致任何数据丢失。 1.2 固态硬盘安装&#xff1a; 确保固态硬盘正确…...

el-table设置自定义css

隔行变色、表头颜色 // 设置table字体颜色、背景色 .el-table {color: #ffffff;background-color: transparent !important; }设置隔行变色功能 .el-table__body {tr.el-table__row {&:nth-child(even) {td.el-table__cell {background-color: #08417f;}}&:nth-child(…...

Compose中导航跳转的实现NavHost

文章目录 1、添加依赖2、两个页面导航跳转的实现2.1 定义导航图2.2 创建导航控制器2.3 实现两个页面跳转 2、带参数的导航2.1 定义带参数的路径2.2 定义接收参数2.3 导航到带参数的屏幕 3、关键点 1、添加依赖 // build.gradle dependencies {implementation "androidx.n…...

VSCode/Cursor中Red Hat Dependency Analytics扩展的自动依赖注入files:分析

VSCode/Cursor中Red Hat Dependency Analytics扩展的自动依赖注入files:分析 问题描述 最近在使用VSCode开发时&#xff0c;发现一个令人困扰的问题&#xff1a;每次打开或保存package.json文件时&#xff0c;都会自动添加一个自引用的依赖项。具体表现为&#xff1a; {&quo…...

【技能篇】RabbitMQ消息中间件面试专题

1. RabbitMQ 中的 broker 是指什么&#xff1f;cluster 又是指什么&#xff1f; 2. 什么是元数据&#xff1f;元数据分为哪些类型&#xff1f;包括哪些内容&#xff1f;与 cluster 相关的元数据有哪些&#xff1f;元数据是如何保存的&#xff1f;元数据在 cluster 中是如何分布…...