我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySql--MVCC

短信预约 信息系统项目管理师 报名、考试、查分时间动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySql--MVCC


	MySql--MVCC
[数据库教程]

一、MVCC是什么?

 

Multi-Vesrion Concurrency Control多版本并发控制,MVCC是一种并发控制的方法,一般在数据库管理系统中,实现对数据库的并发访问。

你可以把MVCC看作一种行级别锁的妥协,在很多情况下避免了锁的使用,同时可以提供更小的开销。根据不同的实现,可以允许非阻塞式读,在写操作时只锁定必要的记录

 MVCC只在REPEATABLE READREAD COMMITTED两个隔离级别下工作。其他两个隔离级别都和MVCC不兼容,因为READ UNCOMMITTED总是读取最新的数据行,而不是符合当前事务版本的数据行,而SERIALIZABLE会对所有读取到的行都加锁。

 

优势:

使用MVCC多版本并发控制比锁定模型的主要优点是在MVCC里,对检索(读)数据的锁要求与写数据的锁要求不冲突,所以读不会阻塞写写也不会阻塞读

恰当的使用MVCC会提供比锁更好的性能。

 

二、MVCC的底层原理

 

InnDB内部结构

 为了实现MVCC机制,InnDB内部为每一行添加了两个隐藏列:DB_TRX_IDDB_ROLL_PTR(MySQL另外还有一个隐藏DB_ROW_ID,这是在InnoDB表没有主键的时候会用来作为主键)。

 DB_TRX_ID:长度为6字节,存储了插入或更新语句的最后一个事务的事务ID。

 DB_ROLL_PTR:长度为7字节,称之为:回滚指针。回滚指针指向写入回滚段的undo log记录,读取记录的时候会根据指针去读取undo log中的记录。(正因为MySQL中undo log中会维护一个历史数据记录,所以我们应该养成定期提交事务的习惯,否则回滚段会越来越   大,甚至占满了表空间。)

 read-view: 当执行查询sql时会生成一致性试图read-view,它由执行查询时所有未提交事务id数组([DB_TRX_ID,DB_TRX_ID]已创建的最大事务id组成(数组里最小id:min_id,最大id:max_id),查询的数据结果需要跟read-view做比对从而得到快照结果。

 

快照读

 快照读是针对上下文的当前读而言,指的是在RR隔离级别下,在不加锁的情况下MySql会根据回滚指针选择从undo log记录中获取快照数据,而不总是获取新的数据,这也就是为什么另一个事务提交了数据,在当前事务中看到的依然是另一个事务提交之前的数据。

 

版本链比较规则(重点):

如果落在绿色部分(trx_id

如果落在红色部分(trx_id>max_id),表示这个版本是由将来启动的事务生成的,是肯定不可见的。

如果落在黄色部分(min_id<=trx_id<=max_id),那就包括两种情况

   a.若row在trx_id在数组中,表示这个版本是由还没提交的事务生成的,不可见,当前自己的事务是可见的

   b.若row的trx_id不在数组中,表示这个版本是已经提交的事务生成的,可见。

技术图片

 

下面逐步分析一下(RR隔离级别下

 

第一步:

有表:table1、table2。table2表中有字段:id、name、db_trx_id、db_roll_ptr(重点看table2)

事务100对table1进行了update(未提交)、事务200对table1进行了update(未提交)、事务300对table2进行了update操作(已提交)

技术图片

 

 

 

update前:版本链中有一条id=1、name=UZI、db_trx_id=60的数据

update中:先将版本链上最新的数据复制一份,然后将trx_id修改成update的trx_id,将db_roll_ptr指向原始数据。

update后:版本链中有两条数据,新数据用指针指向旧数据

技术图片

 

 

 注意:这时readview为[100,200],300,因为事务100未提交、事务200未提交,当前最大db_trx_id=300。

 当在select1中进行select时,trx_id在readview([100,200],300)的黄色区域,且不再数组中,所以name的结果为JackLove。(符合比较规则)

 

第二步:

技术图片

 

 

 事务100又对table2先后进行了两次update操作,在commit前,select1进行了一次select。

 这时版本链内的数据如下:

技术图片

 注意:这时readview也是[100,200],300,因为在一个事务中readview是不可变的,从第一次执行sql开始。

 当在select1中进行select时(trx_id=100),先判断第一条数据,发现在黄色区域且在数组内,则不符合。

 向下找第二条数据,发现也在黄色区域且在数组内,则不符合。

  向下找第三条数据,发现也在黄色区域且不在数组内,符合,所以还是返回name="JackLove"。

 

第三步:

技术图片

 

 事务200分别进行了两次update,在commit前,select1和select2分别进行了一次select;

 这时版本链中的数据如下:

 技术图片

 

 

 

 这时select1(readview:[100,200],300)查询结果是:name="JackLove",

 select2进行select时,事务200未提交,最大max_id=300,所以readview=[200],300,trx_id=200,

 进行逐次比较,结果name="Rookie"

 

对于删除操作:

 对于删除的情况可以认为是update的特殊情况,会将版本链上最新的数据复制一份,然后将trx_id修改成删除操作的trx_id,同时在该条记录的头信息(record header)里的(deleted flag)标记未写上true,来表示当前记录已经被删除,在查询时按照上面的规则查到对应的   记录,如果delete_flag标记为true,意味着记录已被删除,则不返回数据。

 

总结:

MVCC解决了什么问题?

  就是解决了Repeatable Read和Read Committed两个隔离级别下读同一行和写同一行的两个事务的并发。

 

MySql--MVCC

原文地址:https://www.cnblogs.com/BounceGuo/p/13441073.html

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySql--MVCC

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MySql--MVCC

一、MVCC是什么? Multi-Vesrion Concurrency Control多版本并发控制,MVCC是一种并发控制的方法,一般在数据库管理系统中,实现对数据库的并发访问。你可以把MVCC看作一种行级别锁的妥协,在很多情况下避免了锁的使用,同时可以提
MySql--MVCC
2018-07-06

MySQL优化--MVCC

MySQL优化--概述以及索引优化分析MySQL优化--查询分析工具以及各种锁七、MVCC7.1、必备知识7.1.1、什么是MVCC多版本并发控制(Multiversion concurrency control, MCC 或 MVCC),是数据库管理系统常用
MySQL优化--MVCC
2022-03-08

浅析MySQL - MVCC

版本链 在InnoDB引擎表中,他们的聚簇索引记录中有两个隐藏列:trx_id:用来存储对数据进行修改时的事务idroll_pointer:每次对哪条聚簇索引记录有修改的时候,就会把老版本写入undo日志中。这个roll_pointer就是
2022-05-15

MySQL MVCC的详解之Read View

文章目录 概要一、基于UNDO LOG的版本链1.1、行记录结构1.2、了解UNDO LOG1.3、版本链 二、Read View2.1、判定机制2.2、源码 三、参考 概要 在上文中,我们提到了
2023-08-30

mysql mvcc机制有什么用

mysql mvcc 机制用于保证并发事务的隔离性,具体用途包括:避免脏读:防止未提交事务的修改被读取。预防幻读:防止同一行的不同版本被插入或删除。处理不可重复读:同一行数据不会在读取两次时出现不同版本。减少锁争用:使用行级锁定而非表级锁定
mysql mvcc机制有什么用
2024-06-02

mysql中mvcc的具体使用

目录一 MVCC的作用1.1 mvcc的作用1.2 快照读与当前读的区别与联系1.3 快照读1.4 当前读1.5 mvcc可以解决问题1.6 mvcc面试题:mvcc是怎么实现的二 MVCC实现原理2.1 原理2.2 undo log2.
mysql中mvcc的具体使用
2024-09-09

MySQL中的事务和MVCC

本篇博客参考掘金小册——MySQL 是怎样运行的:从根儿上理解 MySQL以及极客时间——MySQL实战45讲。虽然我们不是DBA,可能对数据库没那么了解,但是对于数据库中的索引、事务、锁,我们还是必须要有一个较为浅显的认识,今天我就和大家聊聊事务。为什么要有
MySQL中的事务和MVCC
2014-11-23

mysql的mvcc怎么使用

MySQL的MVCC(Multi-Version Concurrency Control)是一种用于管理并发事务的机制,它可以在不同事务之间提供一致性和隔离性。MVCC允许读取事务在写入事务之前读取数据库中的数据,这样就可以避免读取到未提交
mysql的mvcc怎么使用
2024-04-24

mysql中的mvcc 原理详解

MVCC多版本并发控制,是用来在数据库中控制并发的方法,实现对数据库的并发访问用的,这篇文章主要介绍了mysql mvcc 原理详解,需要的朋友可以参考下
2022-11-13

mysql中MVCC的作用是什么

本篇文章为大家展示了mysql中MVCC的作用是什么,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1、说明多版并发控制MVCC是MySQL InnoDB存储引擎实现隔离等级的具体方法,用于实现提交阅
2023-06-15

Mysql MVCC机制原理详解

什么是MVCCMVCC,全称Multi-Version Concurrency Control,即多版本并发控制。MVCC是一种并发控制的方法,一般在数据库管理系统中,实现对数据库的并发访问,在编程语言中实现事务内存。我们知道,一般情况下我
2022-05-25

mysql的mvcc有什么作用

MySQL的MVCC(Multi-Version Concurrency Control)是一种并发控制机制,它在读取和写入数据时,允许数据库同时存在多个版本的数据。这种机制可以提高数据库的并发性能和可靠性,同时减少数据冲突和锁竞争。MV
mysql的mvcc有什么作用
2024-04-24

编程热搜

目录