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

Mysql DBA学习笔记(MVCC)

主题:InnoDB引擎-MVCC

MVCC:多版本并发控制

一、MVCC相关概念:

1、当前读(current read)

特点:读取记录的最新版本,并对读取记录加锁(保证其他并发事务不能修改当前正在读取的记录),可能会被其他事务阻塞

例子:select ... lock in share mode(共享锁),select ... for update

2、快照读(snapshot read)

特点:读取数据的可见版本(可能是历史版本数据),不加锁,不会被其他事务阻塞

例子:简单select语句

三种隔离级别:
1)Read Committed(读已提交):避免脏读,但可能导致不可重复读

        -每次select,都生成一个快照读

2)Repeatable Read(可重复读):避免脏读和不可重复读,但可能导致幻读

        -开启事务后,第一个select语句是快照读(默认隔离级别)

3)Serializable(串行化):避免发生以上问题

        -快照读=当前读

--所有隔离级别,每个事务在开始时都会创建一个快照。

二、MVCC概念

多版本并发控制(Multi-Version Concurrency Control,简称 MVCC)
是一种数据库并发控制方法,通过维护数据的多个版本来实现读写操作的并行执行
MVCC 的主要目的是实现高并发下的数据一致性与隔离性
它通过为每个事务提供数据的一个“快照”(快照读),确保事务在其执行期间看到的数据是一致的,从而避免了幻读、不可重复读等现象。
此外,MVCC 还减少了锁的使用,降低了锁竞争,提高了系统的吞吐量。

三、MVCC的具体实现原理

数据库记录中的三个隐式字段,undo log日志,readview

1、记录中的三个隐藏字段

在创建表时会自动创建两个隐式字段:DB_TRX_ID和DB_ROLL_PTR,若创建的表没有主键,则会再创建一列DB_ROW_ID作为隐式主键。

  • DB_TRX_ID(transcation id):记录最后一次插入/修改该行记录的事务 ID。
  • DB_ROLL_PTR(回滚指针):指向 Undo Log 的指针(指向这条记录的上一个版本),用于访问该行的历史版本。
2、Undo Log日志(回滚日志)

每当一行数据被修改(INSERT、UPDATE、DELETE)时,InnoDB 会将旧版本的数据存储在 Undo Log 中。

Undo Log 包含以下信息:

  • 事务 ID(trx ID):标识修改该行的事务。

  • 行的旧版本数据:在修改前的行数据。

3、Undo Log 版本链

链表头部为最新记录,尾部为最早的记录。

4、Read View(读视图)

创建 Read View 时,事务会记录活跃未提交的)事务列表和当前事务 ID。(未提交的事务都算做活跃事务

creator_trx_id:RC隔离级别下,执行快照读时会生成一个readview,这个readview对应的creator_trx_id就为当前创建快照读的事务id。

版本链数据访问规则:

trx_id:当前Undo Log记录对应当前事务ID

获取历史版本数据时,判断获取的是哪个版本,就是拿trx_id和上面4个readview核心字段做比较。

另一种对Undo Log的描述版本:

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

  • Read Committed(读已提交):事务中每一次生成快照读时,生成readview。
  • Repeatable Read(可重复读):事务中第一次执行快照读时生成readview,后续复用这一readview。
基本上主要比较的就是版本链数据访问规则中的min_trx_id(最小活跃事务id)来确认快照读生成的是哪一个版本的数据。

四、参考文章/作者

黑马程序员 Mysql数据库从入门到精通。

文章 “MySQL的MVCC是什么?为什么需要MVCC?”,来自华为云,https://bbs.huaweicloud.com/blogs/455611

http://www.dtcms.com/a/394744.html

相关文章:

  • 【论文阅读】GR-1:释放大规模视频生成式预训练用于视觉机器人操控
  • 分布式光伏阴影轨迹模拟
  • 【Java.数据结构】初识集合框架
  • 人工智能的推理方法实验-用归结原理解决机器人搬盒子问题
  • Flink中 Window解析
  • 医疗数据互操作性与联邦学习的python编程方向研究(下)
  • 摄像头视频云存储与回放系统架构
  • C# 压缩解压文件的常用方法
  • .NET驾驭Word之力:打造专业文档 - 页面设置与打印控制完全指南
  • 为什么要创建音频地图?——探索Highcharts可视化的声音创新
  • Sass开发【四】
  • 从图片到实时摄像头:OpenCV EigenFace 人脸识别实战教程
  • kotlin 为什么要有协程作用域
  • MySQL二进制安装
  • 基于Java(SSH)+ Oracle 实现的(Web)视频教学平台
  • 西门子 S7-200 SMART PLC 结构化编程核心:子程序、中断程序与库概念详解
  • 树上LCA和树链剖分(未完待续)
  • 开发避坑指南(54):Mybatis plus查询指定的列
  • SQL注入可能用到的语句
  • 【论文阅读】GR00T N1:面向通用人形机器人的开放基础模型
  • 关于debian老系统安装软件失败的问题
  • ahooks:一套高质量、可靠的 React Hooks 库
  • 【一天一个Web3概念】Uniswap:去中心化金融(DeFi)的自动做市商革命
  • ROS2_YAML参数系统完整指南
  • day01电路基础
  • 贪心算法:以局部最优达成全局最优的艺术
  • Rancher学习
  • 华为认证HCIA备考:Vlan间通信,原理、三层交换机配置实验
  • 104、23种设计模式之访问者模式(13/23)
  • 什么是Mvcc