MySQL——MVCC(多版本并发控制)

news2025/4/15 12:14:41

目录

1.MVCC多版本并发控制的一些基本概念

MVCC实现原理

记录中的隐藏字段

undo log

undo log 版本链

ReadView

数据访问规则

具体实现逻辑

总结


1.MVCC多版本并发控制的一些基本概念

当前读:该取的是记录的最新版本,读取时还要保证其他并发事务不能修改当前记录,会对该取的记录进行加锁。对于我们日常的操作,如:select...lock in share mode(共享锁), select...for update,update,insert. delete(排他锁)都是一种当前读。

快照读:简单的select(不加锁)就是快照读,快照读读取的是记录数据的可见版本,有可能是历史数据,不加锁,是非阻塞读。正常select语句就是一个快照读,

  • read committed:每次select,都生成一个快照读。
  • repeatable read:开启事务后第一个select语句才是快照读的地方。
  • serializable:快照读会退化为当前读。

MVCC:全称multi-versioncurency contol,多版本井发控制,指推护一个数据的多个版本,使得读写提作没有冲突,快照读为MySQL实现。MVCC提供了一个非阻塞读功能。MVCC的具体实现,还需要依赖于数据库记录中的三个隐式字段,undolog日志,readview。

MVCC实现原理

记录中的隐藏字段

DB_TRX_ID:最近修改事务id,记录插入这条记录或者最后一次修改记录的事务id

DB_ROLL_PTR:回滚指针,指向这条记录的上一个版本,用于配合undo log,指向上一个版本

DB_ROW_ID:隐藏主键,如果表结构没有指定主键,将会生成该隐藏字段。

undo log

回滚日志,在insert,update,delete的时候产生的便于数据回滚的日志。记录数据回滚之前是什么样的

insert:产生的undo log日志在回滚时需要,在事务提交后,可被立即删除。

undate,delete:产生undo log日志不仅在回滚时需要,在快照读时也需要,不会被立即删除

undo log 版本链

1.首先事务2去执行sql语句之前InnoDB引擎会在undo log日志里记录数据回滚前是什么样

再去修改数据,DB_TRX_ID会修改为当前事务id,DB_ROLL_PTR会指向回滚日志

2.事务3去修改数据首先会在undo log 日志记录当前数据,再去修改数据DB_TRX_ID修改为3,DB_ROLL_PTR指向当前日志记录,当前日志记录指向前一次记录形成一个版本链

所以undo log版本链指的是:不用事务或者相同事务对同一条记录进行修改,导致该记录的undolog生成一条记录版本链表,链表头部是最最新的旧纪录,链表尾部是最早的旧纪录。

那我们应该选择哪一个版本呢在事务回滚的时候?

ReadView

ReadView(读视图)是快照读SQL执行时MVCC提取数据的依据,记录并维护系统当前活跃的事务(未提交的)id

ReadView包含了四个核心字段:

不同的隔离级别,生成ReadView的时机不同:

read committed:在事务中每一次执行快照读时生成readview.
repeatableread:仅在事务中第一次执行快照读时生成readview,后续复用该readview.

数据访问规则

  • 1.trx_id(当前事务id)==cteator_trx_id(创建快照版本的事务id)?可以访问该版本->  成立,说明数据时当前这个事务更改的
  • 2.trx_id<mix_trx_id(最小活动事务id,最先开启事务还没有提交事务id)?可以访问该版本->  成立,说明数据已经提交了
  • 3.trx_id > max_trx_id?不可以访问该版本->  成立,说明该事务是在readview生成后才开启。
  • 4.min_trx_id <= trx_id <= max_trx_id?如果trx_id不在m_ids中是可以访问该版本的->  说
  • 明数据已经提交

具体实现逻辑

1.m_ids:{3,4,5}由图可知,事务2commited了还有3,4,5没有提交

2.min_trx_id:3 事务3是还没有提交事务的最早开启事务的

3.max_trx_id:6 预先分配事务,下一个事务为6

4.creator_trx_id:5创建readview的为事务5

在RC(read commited)隔离级别下查找快照读版本逻辑

1.当前记录DB_TRX_ID = 4根据数据访问规则去匹配,发现这四条规则一体条都匹配不上,选择去undo log版本链找第二条记录

2.第二条记录当前操作事务id=3,也就是DB_TRX_ID = 3根据数据访问规则去匹配发现这四条规则也一样一条匹配不上,选择去undo log 版本链找第三条记录操作事务id = 2

3.第三条记录当前操作事务id = 2,根据数据数据访问规则去匹配,发现 trx_id < min _ trx_id匹配上了说明这次快照读找的版本是这条记录id = 2,直接把这个版本记录直接返回

在RR(repeatatable)事务隔离级别下,仅在事务中第一次执行快照读时生成ReadView,后续复用该ReadView

在第二次快照读的时候不会生成快照读,复用上面readview,可重复读

两个readview都一样,匹配规则肯定一样,查找出来的数据也是一模一样,这就保证了可重复读

总结

MVCC作用主要我们在快照读的时候来决定我们提取的到底是哪个版本

MVCC实际上实现原理是3部分,隐藏字段,Undo log ,Read View

隐藏字段:主要取决于事务id,和回滚指针

undo log 版本链

Read View读视图

MVCC  + 锁保证了事务当中的隔离性,一致性:指的是数据执行前和执行之后是一致的,如果事务执行失败全部回滚保证数据执行前后一致,一致性由 redo log 和undo log 保证的

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

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

相关文章

Gateway-网关-分布式服务部署

前言 什么是API⽹关 API⽹关(简称⽹关)也是⼀个服务, 通常是后端服务的唯⼀⼊⼝. 它的定义类似设计模式中的Facade模式(⻔⾯模式, 也称外观模式). 它就类似整个微服务架构的⻔⾯, 所有的外部客⼾端访问, 都需要经过它来进⾏调度和过滤. 常⻅⽹关实现 Spring Cloud Gateway&a…

Docker部署MySQL大小写不敏感配置与数据迁移实战20250409

Docker部署MySQL大小写不敏感配置与数据迁移实战 &#x1f9ed; 引言 在企业实际应用中&#xff0c;尤其是使用Java、Hibernate等框架开发的系统&#xff0c;MySQL默认的大小写敏感特性容易引发各种兼容性问题。特别是在Linux系统中部署Docker版MySQL时&#xff0c;默认行为可…

面试题之网络相关

最近开始面试了&#xff0c;410面试了一家公司 问了我几个网络相关的问题&#xff0c;我都不会&#xff01;&#xff01;现在来恶补一下&#xff0c;整理到博客中&#xff0c;好难记啊&#xff0c;虽然整理下来了。在这里先祝愿大家在现有公司好好沉淀&#xff0c;定位好自己的…

[春秋云镜] Tsclient仿真场景

文章目录 靶标介绍&#xff1a;外网mssql弱口令SweetPotato提权上线CSCS注入在线用户进程上线 内网chisel搭建代理密码喷洒攻击映像劫持 -- 放大镜提权krbrelayup提权Dcsync 参考文章 考点: mssql弱口令SweetPotato提权CS注入在线用户进程上线共享文件CS不出网转发上线密码喷洒…

数据集 handpose_x_plus 3D RGB 三维手势 - 手工绘画 场景 draw picture

数据集 handpose 相关项目地址&#xff1a;https://github.com/XIAN-HHappy/handpose_x_plus 样例数据下载地址&#xff1a;数据集handpose-x-plus3DRGB三维手势-手工绘画场景drawpicture资源-CSDN文库

deskflow使用教程:一个可以让两台电脑鼠标键盘截图剪贴板共同使用的开源项目

首先去开源网站下载&#xff1a;Release v1.21.2 deskflow/deskflow 两台电脑都要下载这个文件 下载好后直接打开找到你想要的exe desflow.exe 然后你打开他&#xff0c;将两台电脑的TLS都关掉 下面步骤两台电脑都要完成&#xff1a; 电脑点开edit-》preferences 把这个取…

详解MYSQL表空间

目录 表空间文件 表空间文件结构 行格式 Compact 行格式 变长字段列表 NULL值列表 记录头信息 列数据 溢出页 数据页 当我们使用MYSQL存储数据时&#xff0c;数据是如何被组织起来的&#xff1f;索引又是如何组织的&#xff1f;在本文我们将会解答这些问题。 表空间文…

[Windows] 音速启动 1.0.0.0

[Windows] 音速启动 链接&#xff1a;https://pan.xunlei.com/s/VONiGZhtsxpPzze0lDIH-mR9A1?pwdxu7f# [Windows] 音速启动 1.0.0.0 音速启动是一款桌面管理软件&#xff0c;以仿真QQ界面的形式结合桌面工具的特点&#xff0c;应用于软件文件夹网址的快捷操作。

Hyper-V 虚拟机配置静态IP并且映射到局域网使用

环境 win11hyper-v麒麟v10 配置 编辑文件 vi /etc/sysconfig/network-scripts/ifcfg-eth0文件内容 GATEWAY 需要参考网络中配置的网关地址 TYPEEthernet PROXY_METHODnone BROWSER_ONLYno BOOTPROTOstatic DEFROUTEyes IPV4_FAILURE_FATALno IPV6INITyes IPV6_AUTOCONFyes …

操作系统基础:06 操作系统历史

我们前面已经讲过了操作系统的基本轮廓、启动过程以及系统调用等相关内容&#xff0c;就如同揭开了钢琴的盖子&#xff0c;对操作系统有了初步的表面认识。从现在起&#xff0c;我们要更深入地剖析操作系统&#xff0c;就像分解钢琴一样&#xff0c;探究其各个部分的构成、原理…

【大模型微调】如何解决llamaFactory微调效果与vllm部署效果不一致如何解决

以下个人没整理太全 一、生成式语言模型的对话模板介绍 使用Qwen/Qwen1.5-0.5B-Chat训练 对话模板不一样。回答的内容就会不一样。 我们可以看到例如qwen模型的tokenizer_config.json文件&#xff0c;就可以看到对话模板&#xff0c;一般同系列的模型&#xff0c;模板基本都…

【2025最新】windows本地部署LightRAG,完成neo4j知识图谱保存

之前在服务器部署neo4j失败&#xff0c;无奈只能在本地部署&#xff0c;导致后期所有使用的知识图谱数据都存在本地&#xff0c;这里为了节省时间&#xff0c;先在本地安装LigthRAG完成整个实验流程&#xff0c;后续在学习各种服务器部署和端口调用。从基础和简单的部分先做起来…

14、nRF52xx蓝牙学习(串口 UART 和 UARTE 外设应用)

一、UART 功能描述 串口 UART 也称为通用异步收发器。是各种处理器中常用了通信接口&#xff0c;在 nRF52 芯片中&#xff0c; UART 具有以下特点&#xff1a; ● 全双工操作 ● 自动流控 ● 奇偶校验产生第 9 位数据 串口 UART 的数据发送与接收流程 : ◆硬件配置…

DeepSeek轻松入门教程——从入门到精通

大家好&#xff0c;我是吾鳴。 今天吾鳴要给大家分享一份DeepSeek小白轻松入门指导手册——《DeepSeek 15天指导手册&#xff0c;从入门到精通》。指导手册分为基础入门对话篇、效率飞跃篇、场景实战篇、高手进化篇等&#xff0c;按照指导手册操作&#xff0c;DeepSeek从入门到…

Vue2 老项目升级 Vue3 深度解析教程

Vue2 老项目升级 Vue3 深度解析教程 摘要 Vue3 带来了诸多改进和新特性&#xff0c;如性能提升、组合式 API、更好的 TypeScript 支持等&#xff0c;将 Vue2 老项目升级到 Vue3 可以让项目获得这些优势。本文将深入解析升级过程&#xff0c;涵盖升级前的准备工作、具体升级步骤…

WXJ196微机小电流接地选线装置使用简单方便无需维护

WXJ196微机小电流接地选线装置&#xff0c;能在系统发生单相接地时&#xff0c;准确、迅速地选出接地线路母 线。使用简单方便&#xff0c;无需维护&#xff0c;可根据用户需要将相关信息通过通信接口传给上级监控系统&#xff0c; 适用于无人值守变电站。 2 功能及特点 全新的…

Java第四节:idea在debug模式夏改变变量的值

作者往期文章 Java第一节&#xff1a;debug如何调试程序&#xff08;附带源代码&#xff09;-CSDN博客 Java第二节&#xff1a;debug如何调试栈帧链&#xff08;附带源代码&#xff09;-CSDN博客 Java第三节&#xff1a;新手如何用idea创建java项目-CSDN博客 步骤一 在需要修改…

门极驱动器DRV8353M设计(二)

目录 13.3.4.4 MOSFET VDS 感测 (SPI Only) 13.3.5 Gate Driver保护回路 13.3.5.1 VM 电源和 VDRAIN 欠压锁定 (UVLO) 13.3.5.2 VCP 电荷泵和 VGLS 稳压器欠压锁定 (GDUV) 13.3.5.3 MOSFET VDS过流保护 (VDS_OCP) 13.3.5.3.1 VDS Latched Shutdown (OCP_MODE 00b) 13.…

学点概率论,打破认识误区

概率论是统计分析和机器学习的核心。掌握概率论对于理解和开发稳健的模型至关重要&#xff0c;因为数据科学家需要掌握概率论。本博客将带您了解概率论中的关键概念&#xff0c;从集合论的基础知识到高级贝叶斯推理&#xff0c;并提供详细的解释和实际示例。 目录 简介 基本集合…

NVIDIA AI Aerial

NVIDIA AI Aerial 适用于无线研发的 NVIDIA AI Aerial 基础模组Aerial CUDA 加速 RANAerial Omniverse 数字孪生Aerial AI 无线电框架 用例构建商业 5G 网络加速 5G生成式 AI 和 5G 数据中心 加速 6G 研究基于云的工具 优势100% 软件定义通过部署在数字孪生中进行测试6G 标准化…