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

深度解析Mysql中MVCC的工作机制

MVCC,多版本并发控制

  • 定义:维护一个数据的多个版本,使读写操作没有冲突,依赖于:隐藏字段,undo log日志,readView

  • MVCC会为每条版本记录保存三个隐藏字段

    1. DB_TRX_ID: 记录最近插入或修改该记录的事务ID
    2. DB_ROLL_PTR:回滚指针,指向这条记录的上个版本,配合undo log
    3. DB_ROW_ID隐藏主键,如果没有指定主键,将会生成该隐藏主键

    流程(重点):在修改数据前,innodb引擎会在undo log日志拷贝一份原记录,并将其DB_ROLL_PTR指向上一个版本,形成版本链。然后修改数据值,并把DB_TRX_ID改为当前执行的事务ID
    在这里插入图片描述

  • readView

    1. 定义:确定事务在快照读时能够看到数据库中的哪些数据版本

    2. 区分:

      当前读:读取的是记录的最新版本,对读取的记录加锁,保证读取时其他并发事务不能修改当前记录,解决幻读

      快照读:select查询,不加锁,读取记录数据的可见版本(通过事务ID递增性判断是否可见)

      1. Read Commited每次select都生成一个readView,读取可见记录中的最新版本,会造成不可重复读的问题
      2. Repetable Read:事务首次 select时生成 readView,后续复用该readView**
  1. 定义:确定事务在快照读时能够看到数据库中的哪些数据版本

  2. 区分:

    当前读:读取的是记录的最新版本,对读取的记录加锁,保证读取时其他并发事务不能修改当前记录,解决幻读

    快照读:select查询,不加锁,读取记录数据的可见版本(通过事务ID递增性判断是否可见)

    1. Read Commited每次select都生成一个readView,读取可见记录中的最新版本,会造成不可重复读的问题
    2. Repetable Read:事务首次 select时生成 readView,后续复用该readView
  3. 流程:基于快照读生成的readview,跟要查询的行数据的mvcc版本DB_TRX_ID做比较,基于事务ID的递增性判断mvcc版本是否对当前readview可见,如果可见则返回当前mvcc版本的行数据,如果不可见,则通过mvcc的回滚指针回退到上一个版本。

  4. 判断MVCC版本是否对当前readView可见:mvcc版本的DB_TRX_ID字段readView的字段比较,满足以下任意条件:

    • DB_TRX_ID < min_trx_id(最小事务ID):该版本的事务比所有活跃事务(正在运行)更早创建且已提交,因此可见
    • DB_TRX_ID = creator_trx_id(创建该readview的事务ID):当前事务自己生成的版本(即使未提交),对自己总是可见
    • DB_TRX_ID < max_trx_id(预分配事务ID)&& DB_TRX_ID not in m_ids(活跃的事务ID列表中): 该版本的事务不在创建 read view 时的活跃事务列表中,说明已提交
http://www.lryc.cn/news/2401103.html

相关文章:

  • MP4文件声音与视频分离
  • 接口自动化测试之pytest 运行方式及前置后置封装
  • 服务器被攻击了怎么办
  • 06-排序
  • python,shell,linux,bash概念的不同和对比联系
  • FPGA管脚类型,及选择
  • 如何在 Ubuntu22.04 上安装并开始使用 RabbitMQ
  • R-CNN 模型算法流程梳理
  • 细说C语言将格式化输出到FILE *stream流的函数fprintf、_fprintf_I、fwprintf、_fwprintf_I
  • 本地日记本,用于记录日常。
  • [蓝桥杯]格子刷油漆
  • Monorepo架构: 项目管理工具介绍、需求分析与技术选型
  • ubuntu下libguestfs-tools
  • Authentication failed(切换了新的远程仓库tld)
  • 【Web应用】若依框架:基础篇14 源码阅读-后端代码分析-课程管理模块前后端代码分析
  • 在 Linux 上安装 `pgvector`(这是一个 PostgreSQL 的向量类型扩展,常用于处理嵌入向量,便于进行向量相似度搜索)
  • 09.MySQL内外连接
  • Python爬虫实战:研究Scrapy-Splash库相关技术
  • 智能升级:中国新能源汽车充电桩规模化建设与充电桩智慧管理方案
  • AlphaFold3服务器安装与使用(非docker)(1)
  • 接口自动化测试之pytest接口关联框架封装
  • M1安装并使用Matlab2024a进行java相机标定
  • 02-Redis常见命令
  • 【论文阅读笔记】Text-to-SQL Empowered by Large Language Models: A Benchmark Evaluation
  • 使用ArcPy进行栅格数据分析
  • 华为OD机试真题——告警抑制(2025A卷:100分)Java/python/JavaScript/C/C++/GO最佳实现
  • Java转Go日记(五十七):gin 中间件
  • 《树数据结构解析:核心概念、类型特性、应用场景及选择策略》
  • 在本地查看服务器上的TensorBoard
  • 硬件开发全解:从入门教程到实战案例与丰富项目资源