分布式不同数据的一致性模型
1. 强一致性(Strong Consistency)
- 定义:所有节点在任何时间点看到的数据完全一致,读操作总是返回最近的写操作结果。
- 特点:
- 写操作完成后,所有后续读操作都能立即看到更新。
- 通常需要同步机制(如分布式锁或两阶段提交)。
- 牺牲部分可用性和性能以保证一致性。
- 优点:
- 数据高度可靠,适合需要严格正确性的场景。
- 客户端逻辑简单,无需处理数据不一致。
- 缺点:
- 在网络分区或高延迟时,可能导致系统不可用(符合 CAP 的 CP 模型)。
- 写操作延迟较高,因为需要跨节点同步。
- 实现方式:
- 两阶段提交(2PC)、Paxos、Raft 共识算法。
- 数据库例子:Google Spanner(通过 TrueTime 实现)、ZooKeeper。
- 应用场景:
- 金融系统(银行账户、交易)。
- 库存管理(防止超卖)。
- 分布式锁和协调服务(ZooKeeper)。
2. 最终一致性(Eventual Consistency)
- 定义:如果没有新的写操作,系统最终会使所有节点的数据达到一致,但短期内可能存在不一致。
- 特点:
- 写操作后,节点间数据可能暂时不一致,但通过同步机制(如后台复制)最终一致。
- 优先保证可用性和分区容错性(符合 CAP 的 AP 模型)。
- 优点:
- 高可用性,系统在网络分区时仍可响应。
- 写操作延迟低,适合高并发场景。
- 缺点:
- 客户端可能读取到旧数据,需处理不一致性。
- 一致性收敛时间可能较长,依赖系统设计。
- 实现方式:
- 异步复制、冲突解决机制(如向量时钟、CRDT)。
- 数据库例子:Cassandra、DynamoDB、CouchDB。
- 应用场景:
- 社交媒体(帖子、评论更新)。
- 内容分发网络(CDN)。
- 日志收集和分析系统。
最终一致性的子类型
- 因果一致性(Causal Consistency):
- 保证因果相关的操作按顺序执行(如 A 导致 B,则所有节点先看到 A 再看到 B)。
- 例子:Riak(部分配置)、Dynamo。
- 场景:消息系统、社交网络的事件流。
- 会话一致性(Session Consistency):
- 在同一会话内,读操作能看到之前的写操作结果。
- 例子:Redis(部分配置)、Memcached。
- 场景:用户会话管理、购物车。
- 单调读一致性(Monotonic Read Consistency):
- 如果客户端读取到某个值,后续读操作不会返回更旧的值。
- 场景:缓存系统、推荐系统。
- 单调写一致性(Monotonic Write Consistency):
- 保证同一客户端的写操作按提交顺序执行。
- 场景:日志系统、事件溯源。
3. 读写一致性(Read-your-Writes Consistency)
- 定义:客户端在写入数据后,立即读取时能保证看到自己的写结果。
- 特点:
- 强调客户端的写后读一致性,不要求全局一致。
- 常用于最终一致性系统的增强。
- 优点:
- 提高用户体验,避免写后读到旧数据的困惑。
- 实现成本较低。
- 缺点:
- 不保证其他客户端的一致性。
- 依赖客户端会话管理。
- 实现方式:
- 会话粘性(Sticky Sessions)、客户端缓存。
- 数据库例子:MongoDB(读写分离配置)。
- 应用场景:
- 用户账户更新(如密码修改后立即生效)。
- 个人化设置(如主题切换)。
4. 顺序一致性(Sequential Consistency)
- 定义:所有节点的读写操作按全局统一的顺序执行,操作结果与某种顺序化的执行一致。
- 特点:
- 比强一致性稍弱,不要求实时同步,但要求操作顺序一致。
- 所有客户端看到相同的操作顺序。
- 优点:
- 提供较强的一致性保证,同时比强一致性性能稍好。
- 适合需要明确操作顺序的场景。
- 缺点:
- 仍可能牺牲部分可用性。
- 实现复杂,需协调机制。
- 实现方式:
- 分布式日志、共识算法。
- 数据库例子:CockroachDB(部分场景)。
- 应用场景:
- 分布式任务队列。
- 协作编辑系统(如 Google Docs 的操作序列)。
5. 弱一致性(Weak Consistency)
- 定义:对数据一致性几乎没有保证,客户端可能读取到任意数据状态。
- 特点:
- 优先最大化可用性和性能。
- 通常依赖客户端或应用程序自行处理一致性。
- 优点:
- 极高的可用性和低延迟。
- 适合对一致性要求极低的场景。
- 缺点:
- 数据不一致风险高,客户端逻辑复杂。
- 实现方式:
- 无同步的分布式缓存、简单复制。
- 数据库例子:某些 NoSQL 数据库在最低一致性配置下。
- 应用场景:
- 实时游戏状态(短暂不一致可接受)。
- 非关键性缓存(如广告展示)。
一致性模型对比
一致性模型 | 一致性强度 | 可用性 | 延迟 | 典型应用场景 |
---|---|---|---|---|
强一致性 | 高 | 低 | 高 | 金融、库存管理 |
最终一致性 | 低 | 高 | 低 | 社交媒体、CDN |
因果一致性 | 中 | 高 | 中 | 消息系统、事件流 |
会话一致性 | 中 | 高 | 低 | 购物车、用户会话 |
顺序一致性 | 高 | 中 | 中 | 任务队列、协作编辑 |
弱一致性 | 低 | 高 | 低 | 实时游戏、非关键缓存 |
相关文章:
分布式不同数据的一致性模型
1. 强一致性(Strong Consistency) 定义:所有节点在任何时间点看到的数据完全一致,读操作总是返回最近的写操作结果。特点: 写操作完成后,所有后续读操作都能立即看到更新。通常需要同步机制(如…...
“application/json“,“text/plain“ 分别表示什么
这两个字符串:“application/json” 和 “text/plain” 是 MIME 类型(媒体类型),用于告诉接收方消息内容的格式,它们出现在 ContentType 字段中。 它告诉系统或程序:“这段数据是什么格式?” 格…...
SQL: 窗口滑动(Sliding Window)
目录 什么是“窗口”? 什么是“滑动”? 🔍 滑动窗口的核心: 🕒 什么是时间窗口?(Time Window) 时间窗口的基本结构 时间窗口的三种常见形式 📊 什么是行窗口&…...

学习日记-day20-6.1
完成目标: 知识点: 1.集合_Collections集合工具类 方法:static <T> boolean addAll(Collection<? super T> c, T... elements)->批量添加元素 static void shuffle(List<?> list) ->将集合中的元素顺序打乱static <T>…...

【音视频】 FFmpeg 解码H265
一、概述 实现了使用FFmpeg读取对应H265文件,并且保存为对应的yuv文件 二、实现流程 读取文件 将H265/H264文件放在build路径下,然后指定输出为yuv格式 在main函数中读取外部参数 if (argc < 2){fprintf(stderr, "Usage: %s <input file&…...
Linux 系统 Docker Compose 安装
个人博客地址:Linux 系统 Docker Compose 安装 | 一张假钞的真实世界 本文方法是直接下载 GitHub 项目的 release 版本。项目地址:GitHub - docker/compose: Define and run multi-container applications with Docker。 执行以下命令将发布程序加载至…...

软件测试|FIT故障注入测试工具——ISO 26262合规下的智能汽车安全验证引擎
FIT(Fault Injection Tester)是SURESOFT专为汽车电子与工业控制设计的自动化故障注入测试工具,基于ISO 26262等国际安全标准开发,旨在解决传统测试中效率低、成本高、安全隐患难以复现的问题,其核心功能包括…...

3D拟合测量水杯半径
1,目的。 测量水杯的半径 如图所示: 2,原理。 对 3D 点云对象 进行圆柱体拟合,获取拟合后的半径。 3,注意事项。 在Halcon中使用fit_primitives_object_model_3d进行圆柱体拟合时,输出的primitive_para…...
(21)量子计算对密码学的影响
文章目录 2️⃣1️⃣ 量子计算对密码学的影响 🌌🔍 TL;DR🚀 量子计算:密码学的终结者?⚡ 量子计算的破坏力 🔐 Java密码学体系面临的量子威胁🔥 受影响最严重的Java安全组件 🛡️ 后…...

Python训练打卡Day38
Dataset和Dataloader类 知识点回顾: Dataset类的__getitem__和__len__方法(本质是python的特殊方法)Dataloader类minist手写数据集的了解 在遇到大规模数据集时,显存常常无法一次性存储所有数据,所以需要使用分批训练的…...

Selenium基础操作方法详解
Selenium基础操作方法详解:从零开始编写自动化脚本(附完整代码) 引言 Selenium是自动化测试和网页操作的利器,但对于新手来说,掌握基础操作是成功的第一步。本文将手把手教你使用Selenium完成浏览器初始化、元素定位、…...
Kali Linux从入门到实战:系统详解与工具指南
一、Kali Linux简介 Kali Linux是一款基于Debian的Linux发行版,专为渗透测试和网络安全审计设计,由Offensive Security团队维护。其前身是BackTrack,目前集成了超过600款安全工具,覆盖渗透测试全流程,是网络安全领域…...
【大模型】Bert变种
1. RoBERTa(Robustly optimized BERT approach) 核心改动 取消 NSP(Next Sentence Prediction)任务,研究发现 NSP 对多数下游任务贡献有限。动态遮蔽(dynamic masking):每个 epoch …...
vue-09(使用自定义事件和作用域插槽构建可重用组件)
实践练习:使用自定义事件和作用域插槽构建可重用组件 构建可重用的组件是高效 Vue.js 开发的基石。本课重点介绍如何通过自定义事件和范围插槽来增强组件的可重用性,从而实现更灵活和动态的组件交互。我们将探索如何定义和发出自定义事件,使…...

简单三步FastAdmin 开源框架的安装
简单三步FastAdmin 开源框架的安装 第一步:新建站点1,在宝塔面板中,创建一个新的站点,并填写项目域名。 第二步:上传框架1,框架下载2,上传解压缩 第三步:配置并安装1,进入…...

RISC-V 开发板 MUSE Pi Pro 搭建 Spacengine AI模型部署环境
视频讲解: RISC-V 开发板 MUSE Pi Pro 搭建 Spacengine AI模型部署环境 Spacengine 是由 进迭时空 研发的一套 AI 算法模型部署工具,可以方便的帮助用户部署自己的模型在端侧, 环境部署的方式,官方提供了两种方式: do…...
C++面试5——对象存储区域详解
C++对象存储区域详解 核心观点:内存是程序员的战场,存储区域决定对象的生杀大权!栈对象自动赴死,堆对象生死由你,全局对象永生不死,常量区对象只读不灭。 一、四大地域生死簿 栈区(Stack) • 特点:自动分配释放,速度极快(类似高铁进出站) • 生存期:函数大括号{}就…...

【Unity】AudioSource超过MaxDistance还是能听见
unity版本:2022.3.51f1c1 将SpatialBlend拉到1即可 或者这里改到0 Hearing audio outside max distance - #11 by wderstine - Questions & Answers - Unity Discussions...
基于 51 单片机的智能饮水机控制系统设计与实现
一、引言 随着物联网技术的发展,传统家电的智能化升级成为趋势。本文提出一种基于 51 单片机的智能饮水机设计方案,实现水温精准控制、水位监测、人机交互等功能,具有成本低、稳定性高的特点,适用于家庭和小型办公场景。 二、硬件设计 2.1 核心芯片选型 单片机:选用STC…...

Qt 读取和写入 INI 格式的配置文件
Qt 读取和写入 INI 格式的配置文件 前言:INI 配置文件在 Qt 开发中的重要性基础夯实:INI 文件结构与 QSettings 核心概念1. INI 文件的基本结构2. QSettings 类概述3. 初始化 QSettings 对象4. 基本读写操作5. 高级操作技巧5.1 处理数组和列表5.2 检查键…...
互联网大厂Java求职面试:AI与云原生架构实战解析
互联网大厂Java求职面试:AI与云原生架构实战解析 面试背景设定 场景:某互联网头部企业技术总监办公室,窗外是城市夜景,室内灯光柔和。面试官是一位经验丰富的技术总监,面前摆着一杯黑咖啡和候选人的简历。 候选人&a…...

Spring:从青铜到王者,你的Java修炼手册
一、Spring家族宇宙:原来你是这样的框架(青铜段位) 1.1 Spring的"前世今生":从泡面到满汉全席 2002年的泡面哲学:Rod Johnson在厨房煮泡面时突然顿悟:"Java开发为什么不能像泡面一…...
React和原生事件的区别
一、核心差异对比表 维度原生事件React 事件绑定语法HTML 属性(onclick)或 DOM API(addEventListener)JSX 中使用驼峰式属性(onClick)绑定位置直接绑定到具体 DOM 元素统一委托到根节点(React …...

Qt creator 设计页面控件认识与了解
记录一下 Qt 中的认识与了解: 在 Qt 中,这些功能属于 Qt Designer 的组件过滤系统,旨在帮助开发者在对象浏览器中快速定位和使用不同类型的控件和组件。以下是每个功能的详细讲解: Layouts(布局)&…...
命象架构法 02|你的系统有“用神”吗?
命理中说:“八字无用神,是虚命。” 系统架构中说:“模块无主线,是垃圾桶。” 你设计了无数类,却不知道哪个是核心。 那么你的系统,很可能是没有“用神”的。 01|什么是“用神”?不是你以为的“最好” 命理中,“用神”不是“最强的”,而是对命主最有帮助的。 比如一…...

NVIDIA Mellanox BlueField-2 DPU(Data Processing Unit)智能网卡的调试和使用
专有名词 OOB: BMC: BFB: EMMC: 关键词解释eMMCEmbedded Multi-Media Card——把 NAND 闪存颗粒与控制器封装在一起的板载存储件,类似手机里的“内置储存” .deb:文件是Debian软件包格式的专…...

Tomcat- AJP协议文件读取/命令执行漏洞(幽灵猫复现)详细步骤
一、漏洞描述 Apache Tomcat是由Apache软件基金会属下Jakarta项目开发的Servlet容器.默认情况下,Apache Tomcat会开启AJP连接器,方便与其他Web服务器通过AJP协议进行交互.但Apache Tomcat在AJP协议的实现上存在漏洞,导致攻击者可以通过发送恶意的AJP请求,可以读取或者包含Web应…...

B1、进度汇报(— 25/05/31)
本文档汇总了各成员在 2025 年 5 月 11 日 ~ 5 月 31 日完成的工作。我们遇到了进度问题(收工后需反思): 本学期第十四周(05/19 ~ 05/25)有相当多课程需要提交实验结果或上台展示。本学期第十六周(06/02 ~…...
工作流引擎-11-开源 BPM 项目 jbpm
工作流引擎系列 工作流引擎-00-流程引擎概览 工作流引擎-01-Activiti 是领先的轻量级、以 Java 为中心的开源 BPMN 引擎,支持现实世界的流程自动化需求 工作流引擎-02-BPM OA ERP 区别和联系 工作流引擎-03-聊一聊流程引擎 工作流引擎-04-流程引擎 activiti 优…...
【Prompt Engineering】摸索出的一些小套路
prompt 优化方法 🔹 1. 通用结构模板 模块化的Prompt:Prompt 划分成边界清晰的模块,不同模块间都应有明确的分隔符 以下是通用 Prompt 的推荐结构: [角色设定] [任务描述] [输出格式要求] [补充上下文]角色设定:…...