MySQL MVCC的快照读和当前读区别,Redis的RDB+AOF混合持久化流程。

MySQL MVCC 的快照读和当前读区别

快照读 (Snapshot Read)

  • 定义: 读取数据的历史版本(快照),基于 MVCC(多版本并发控制)实现。
  • 特点:
    • 不加锁,非阻塞读。
    • 返回事务开始时的快照数据,确保一致性。
    • 依赖 Undo Log 和版本链。
  • 适用场景: 普通的 SELECT 查询。
  • 示例:
SELECT * FROM user WHERE id = 1;
  • 隔离级别: Read Committed(读已提交) 和 Repeatable Read(可重复读) 中常用。

当前读 (Current Read)

  • 定义: 读取数据的最新版本,通常涉及加锁。
  • 特点:
    • 加锁操作,保证数据一致性。
    • 返回最新提交的数据。
    • 使用行锁、间隙锁等机制。
  • 适用场景: 加锁查询或写操作(如 UPDATE、DELETE)。
  • 示例:
SELECT * FROM user WHERE id = 1 FOR UPDATE;  -- 排他锁
UPDATE user SET name = 'Tom' WHERE id = 1;
  • 隔离级别: 适用于所有隔离级别。

主要区别

特性快照读当前读
数据版本历史快照最新数据
是否加锁不加锁加锁
实现方式MVCC + Undo Log锁 + 最新数据
示例普通 SELECT加锁 SELECT, DML

Redis RDB + AOF 混合持久化流程

  • Redis 在 4.0 版本引入了 RDB 和 AOF 的混合持久化,结合 RDB 的快速恢复和 AOF 的数据完整性。以下是流程:

1. 开启混合持久化

  • 配置:
# confaof-use-rdb-preamble yes  # 启用混合持久化

2. 数据写入

  • 客户端写命令(如 SET、DEL)被记录到 AOF 缓冲区。

3. 触发重写

  • 手动触发: BGREWRITEAOF 命令。
  • 自动触发: 根据 AOF 文件大小增长规则。

4. 混合持久化过程

  1. 生成 RDB 快照:
    • 子进程将当前内存数据生成 RDB 文件。
  2. 写入 AOF 文件:
    • 将 RDB 快照写入新 AOF 文件的开头。
  3. 追加增量命令:
    • 子进程生成快照期间,主进程缓冲写命令。
    • 快照完成后,将缓冲区的命令以 AOF 格式追加到文件。
  4. 替换旧文件:
    • 新 AOF 文件(RDB + AOF 增量)原子替换旧文件。

5. 数据恢复

  • 重启时:
    1. 加载 AOF 文件中的 RDB 部分,快速恢复内存。
    2. 执行后续 AOF 命令,补齐增量变更。

配置示例

# conf
save 900 1           # RDB 触发条件
appendonly yes       # 启用 AOF
aof-use-rdb-preamble yes  # 混合持久化

优点

  • RDB: 文件小,恢复快。
  • AOF: 数据丢失少。
  • 混合: 兼顾速度和完整性。

总结

  • MySQL MVCC:
    • 快照读:历史数据,无锁。
    • 当前读:最新数据,加锁。
  • Redis 混合持久化:
    • RDB 提供初始快照,AOF 追加增量,子进程重写,原子替换。

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

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

相关文章

Cesium 自定义路径导航材质

cesium 自定义路径导航纹理图片随便更换,UI 提供设计图片即可达到效果; 打开小马的weix 关注下 搜索“技术链” 回复关键词《《路径》》获取原始代码; 拿到就能用轻松解决!帮忙点个关注吧!

3月25号

添加图片的一些例子: // 创建一个二维数组,用来管理数据int[][] data new int[4][4]; // 记录空白方块的位置int x0;int y0; // 定义一个变量,记录当前展示图片的路径String path"E:\\java\\jigsawgame\\路飞\\路飞"; // 加载图片细节: // …

【机器学习】什么是支持向量机?

什么是支持向量机? 支持向量机(SVM,Support Vector Machine)是一种强大的机器学习算法,常用于分类问题,也可以用于回归问题。它的核心思想是通过找到一个最佳的“超平面”来将不同类别的数据分开&#xff…

10分钟打造专属AI助手!ToDesk云电脑/顺网云/海马云操作DeepSeek哪家强?

文章目录 一、引言云计算平台概览ToDesk云电脑:随时随地用上高性能电脑 二 .云电脑初体验DeekSeek介绍版本参数与特点任务类型表现 1、ToDesk云电脑2、顺网云电脑3、海马云电脑 三、DeekSeek本地化实操和AIGC应用1. ToDesk云电脑2. 海马云电脑3、顺网云电脑 四、结语…

Spring Boot 一个接口实现任意表的 Excel 导入导出

Java的web开发需要excel的导入导出工具,所以需要一定的工具类实现,如果是使用easypoi、Hutool导入导出excel,会非常的损耗内存,因此可以尝试使用easyexcel解决大数据量的数据的导入导出,且可以通过Java8的函数式编程解…

QT原子变量:QAtomicInteger、QAtomicPointer、QAtomicFlag

引言:原子变量为何重要? 在多线程编程中,共享数据的原子性访问是保证线程安全的核心。传统互斥锁虽然有效,但会带来性能损耗和死锁风险。QT提供的原子类型(QAtomicInteger、QAtomicPointer、QAtomicFlag)通…

大模型金融企业场景落地应用

一、商业银行体系 1. 江苏银行 企业背景:江苏银行是总部位于江苏南京的全国性股份制商业银行,在城商行中资产规模位居前列,积极拥抱金融科技,将数字化转型作为核心战略之一。近年来,江苏银行持续加大在人工智能、大数…

卡特兰数在数据结构上面的运用

原理 Catalan数是一个数列,其第n项表示n个不同结点可以构成的二叉排序树的数量。Catalan数的第n项公式为:  其中,是组合数,表示从2n个元素中选择n个元素的组合数。 Catalan数的原理可以通过以下方式理解&…

影视后期工具学习之PR(中)

pr剪辑之旅----声音设计 第五课 镜头语言和绿幕抠像 超级键效果(超级键通过简单的吸管取色和参数调整,即可实现专业级抠像与合成效果。无论是绿幕替换背景,还是创意双重曝光,都能轻松驾驭。建议结合「Alpha 通道」视图观察透明区域,逐步优化细节,最终导出高质量视频。)…

使用BootStrap 3的原创的模态框组件,没法弹出!估计是原创的bug

最近在给客户开发一个CRM系统,其中用到了BOOTSTRAP的模态框。版本是3。由于是刚开始用该框架。所以在正式部署到项目中前,需要测试一下,找到框架中的如下部分。需要说明的是。我用的asp.net mvc框架开发。测试也是在asp.net mvc环境下。 复制…

Camera2 与 CameraX 闲谈

目录 📂 前言 1. 🔱 Camera2 2. 🔱 CameraX 3. 🔱 Camera2 与 CameraX 1)使用复杂度与开发效率 2)控制能力与应用场景 3)设备兼容性与稳定性 4)更新与维护 4. &#x1f4a0…

【大语言模型_8】vllm启动的模型通过fastapi封装增加api-key验证

背景: vllm推理框架启动模型不具备api-key验证。需借助fastapi可以实现该功能 代码实现: rom fastapi import FastAPI, Header, HTTPException, Request,Response import httpx import logging# 创建 FastAPI 应用 app FastAPI() logging.basicConfig(…

基于SpringBoot的名著阅读网站

作者:计算机学姐 开发技术:SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等,“文末源码”。 专栏推荐:前后端分离项目源码、SpringBoot项目源码、Vue项目源码、SSM项目源码、微信小程序源码 精品专栏:…

Langchain 自定义工具和内置工具

使用介绍 自定义工具时的元素概念介绍 在Langchain中,工具(Tool)是与语言模型交互的基本单元。以下是自定义工具时的关键元素: name 定义:工具的名称,用于唯一标识该工具。作用:当工具被集成…

Gitee上库常用git命令

Gitee上库常用git命令 1、Fork 项目2、个人仓库修改3、追加提交4、创建PR5、多笔commit合一 1、Fork 项目 2、个人仓库修改 git add . // -s 表示自动添加邮箱签名信息,-m表示其后跟随commit描述 git commit -sm “add transition freeze” git push origin [目标…

Java 大视界 -- Java 大数据在智慧农业精准灌溉与施肥决策中的应用(144)

💖亲爱的朋友们,热烈欢迎来到 青云交的博客!能与诸位在此相逢,我倍感荣幸。在这飞速更迭的时代,我们都渴望一方心灵净土,而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识,也…

Redux,React-redux。基础

状态管理库,集中式存储状态,管理状态 ✅ redux //简单实现 redux源码 export function createStore(reducer) {// reducer由用户编写, 必须是一个函数,dispatch的时候,reducer要执行if (typeof reducer ! function) t…

5.2 位运算专题:LeetCode 268. 丢失的数字

1. 题目链接 LeetCode 268. 丢失的数字 2. 题目描述 给定一个包含 [0, n] 范围内 n 个不同整数的数组 nums(实际长度为 n),找出数组中缺失的那个数字。 示例: 输入:nums [3,0,1] → 输出:2(…

基于第三方库的人脸识别系统的设计与实现

标题:基于第三方库的人脸识别系统的设计与实现 内容:1.摘要 本文针对传统人脸识别系统开发复杂、效率低的问题,旨在设计并实现基于第三方库的人脸识别系统。通过选用合适的第三方人脸识别库,利用其成熟的算法和接口,简化系统开发流程。对收集…

【Android】VehiclePropertyAccess引起CarService崩溃

VehiclePropertyAccess引起CarService崩溃 VehiclePropertyAccess VehiclePropertyAccess属性,用于定义车辆属性的访问权限。权限包括 读:READ,只可以读取,不能写入。 VehiclePropertyAccess:READ写:WRITE&#xf…