广告
返回顶部
首页 > 资讯 > 数据库 >MySQL的多版本并发控制MVCC实现方法是什么
  • 210
分享到

MySQL的多版本并发控制MVCC实现方法是什么

2023-06-22 05:06:27 210人浏览 薄情痞子
摘要

这篇文章主要讲解了“MySQL的多版本并发控制mvcC实现方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Mysql的多版本并发控制MVCC实现方法是什么”吧!什么是MVCCMVCC

这篇文章主要讲解了“MySQL的多版本并发控制mvcC实现方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Mysql的多版本并发控制MVCC实现方法是什么”吧!

什么是MVCC

MVCC就是多版本并发控制。

mysql事务型存储引擎通过多版本并发控制(MVCC)来提升并发性能。

可以认为MVCC是行级的一个变种,但是它在大多数情况下避免了加锁操作,同时实现非阻塞的读操作,因此开销更低。

MVCC是通过保存数据在某个时间点的快照来实现的,核心思想就是保存数据的历史版本,通过对数据行的多个版本管理来实现数据库的并发控制。

这样我们就可以通过比较版本号决定数据是否显示出来,读取数据的时候不需要加锁也可以保证事务的隔离效果。

MVCC的实现

实际上,InnoDB 会在每行记录后面增加三个隐藏字段:

  • ROW_ID:行ID,随着插入新行而单调递增,如果有主键,则不会包含该列。

  • TRX_ID:记录插入或更新该行的事务的事务ID。

  • ROLL_PTR:回滚指针,指向 undo log 记录。每次对某条记录进行改动时,该列会存一个指针,可以通过这个指针找到该记录修改前的信息。当某条记录被多次修改时,该行记录会存在多个版本,通过 ROLL_PTR 链接形成一个类似版本链的概念。

MySQL的多版本并发控制MVCC实现方法是什么

以 RR 级别为例:

每开启一个事务时,系统会给该事务分配一个事务 Id,在该事务执行第一 个 select 语句的时候,会生成一个当前时间点的事务快照 ReadView,主要包含以下几个属性:

  • m_ids:表示生成ReadView时,当前系统中未提交的读写事务的事务id列表。

  • min_trx_id:表示生成ReadView时,当前系统中未提交的读写事务中最小的事务id,也就是m_ids中的最小值。

  • max_trx_id:表示生成ReadView时,系统中应该分配给下一个事务的id值。

  • creator_trx_id:表示生成ReadView时,该事务的事务id。

有了这个 ReadView,这样在访问某条记录时,只需要按照下边的步骤判断记录的某个版本是否可见:

  • trx_id == creator_trx_id:可以访问这个版本。

  • trx_id < min_trx_id :可以访问这个版本。

  • trx_id > max_trx_id:不可以访问这个版本。

  • min_trx_id <= trx_id <= max_trx_id :如果trx_id是在m_ids中,不可以访问这个版本,反之可用。

在进行判断时,首先会拿记录的最新版本来比较,如果该版本无法被当前事务看到,则通过记录的 ROLL_PTR 找到上一个版本,重新进行比较,直到找到一个能被当前事务看到的版本。
而对于删除,其实就是一种特殊的更新,InnoDB 用一个额外的标记位 delete_bit 标识是否删除。当我们在进行判断时,会检查下 delete_bit 是否被标记,如果是,则跳过该版本,通过 ROLL_PTR 拿到下一个版本进行判断。

以上内容是对于 RR 级别来说,而对于 RC 级别,其实整个过程几乎一样,唯一不同的是生成 ReadView 的时机, RR 级别只在事务开始时生成一次,之后一直使用该 ReadView。而 RC 级别则在每次 select 时,都会生成一个 ReadView。

MVCC 有没有解决幻读?

幻读:在一个事务中使用相同的 sql 进行两次读取,第二次读取到了其他事务新插入的行。
例如:

1)事务 1 第一次查询:select * from user where id < 10 时查到了 id = 1 的数据

2)事务 2 插入了 id = 2 的数据

3)事务 1 使用同样的语句第二次查询时,查到了 id = 1、id = 2 的数据,出现了幻读。

谈到幻读,首先我们要引入“当前读”和“快照读”的概念。

  • 快照读:生成一个事务快照(ReadView),之后都从这个快照获取数据。普通 select 语句就是快照读。

  • 当前读:读取数据的最新版本。常见的 update/insert/delete、还有 select ... for update、select ... lock in share mode 都是当前读。

对于快照读,MVCC 因为从 ReadView 读取,所以必然不会看到新插入的行,所以天然就解决了幻读的问题。

而对于当前读的幻读,MVCC 是无法解决的。需要使用 Gap Lock 或 Next-Key Lock(Gap Lock + Record Lock)来解决。

其实原理也很简单,用上面的例子稍微修改下以触发当前读:

select * from user where id < 10 for update

当使用了 Gap Lock 时,Gap 锁会锁住 id < 10 的整个范围,因此其他事务无法插入 id < 10 的数据,从而防止了幻读。

感谢各位的阅读,以上就是“MySQL的多版本并发控制MVCC实现方法是什么”的内容了,经过本文的学习后,相信大家对MySQL的多版本并发控制MVCC实现方法是什么这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

您可能感兴趣的文档:

--结束END--

本文标题: MySQL的多版本并发控制MVCC实现方法是什么

本文链接: https://www.lsjlt.com/news/302908.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • MySQL的多版本并发控制MVCC实现方法是什么
    这篇文章主要讲解了“MySQL的多版本并发控制MVCC实现方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL的多版本并发控制MVCC实现方法是什么”吧!什么是MVCCMVCC...
    99+
    2023-06-22
  • mysql多版本并发控制MVCC的实现
    事务隔离级别设置 set global transaction isolation level read committed; //全局的 set session transaction isolat...
    99+
    2022-10-18
  • mysql的MVCC多版本并发控制的实现
    1 什么是MVCC MVCC全称是: Multiversion concurrency control,多版本并发控制,提供并发访问数据库时,对事务内读取的到的内存做处理,用来避免写操作堵塞读操作的并发问题。 举个...
    99+
    2022-05-31
    mysql MVCC多版本并发控制 mysql 多版本并发控制
  • MySQL的多版本并发控制MVCC的实现
    目录什么是MVCC MVCC的实现 MVCC 有没有解决幻读? 什么是MVCC MVCC就是多版本并发控制。 MySQL的事务型存储引擎通过多版本并发控制(MVCC)来提升并发性...
    99+
    2022-11-12
  • 怎么在mysql中实现MVCC多版本的并发控制
    今天就跟大家聊聊有关怎么在mysql中实现MVCC多版本的并发控制,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1 什么是MVCCMVCC全称是: Multiversion conc...
    99+
    2023-06-14
  • MYSQL的多版本并发控制MVCC(Multi-Version Concurrency Control)
    1、概述 MVCC是一种用于数据库管理系统的并发控制技术,允许多个事务同时访问数据库,而不会导致读写冲突。也就是说在读写的时候,线程不用去争抢读写锁。因为加锁的过程比较耗性能。 当然很多时候还是必须的,不能避免,比如说,去ATM机取钱的时候...
    99+
    2023-09-25
    mysql MVCC MYSQL多版本并发控制
  • Mysql MVCC多版本并发控制的知识点有哪些
    这篇文章主要介绍了Mysql MVCC多版本并发控制的知识点有哪些的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Mysql MVCC多版本并发控制的知识点有哪些文章都会有所收获,下面我们一起...
    99+
    2023-06-30
  • MySQL MVVC多版本并发控制的实现详解
    目录一、概述二、快照读与当前读1.当前读2.快照读三、隔离级别与版本链复习四、Read View1.实现原理2.Read View规则3.整体流程五、举例1.READ2.REPEATABLE READ隔离级别下3.如何解...
    99+
    2022-08-24
  • MySQLMVVC多版本并发控制的实现详解
    目录一、概述二、快照读与当前读1.当前读2.快照读三、隔离级别与版本链复习四、Read View1.实现原理2.Read View规则3.整体流程五、举例1.READ2.REPEAT...
    99+
    2022-11-13
  • MySQL MVCC 原理解析:为什么是并发控制的最佳选择?
    MySQL MVCC 原理解析:为什么是并发控制的最佳选择?在关系型数据库中,数据的一致性和并发控制是至关重要的。MySQL作为最流行的关系型数据库管理系统之一,采用了MVCC(Multi-Version Concurrency Contr...
    99+
    2023-10-22
    mvcc 并发控制 关键词:MySQL
  • golang并发控制的方法是什么
    在Go语言中,可以使用以下几种方法来控制并发:1. Goroutine:Goroutine是Go语言中的轻量级线程,可以通过go关键...
    99+
    2023-10-20
    golang
  • golang控制并发数的方法是什么
    在Golang中,可以使用goroutine和channel来控制并发数。以下是几种常见的方法: 通过控制goroutine的数...
    99+
    2023-10-27
    golang
  • golang控制并发数量的方法是什么
    在golang中,可以使用goroutine和channel来控制并发数量。以下是一些常用的方法: 使用goroutine和Wai...
    99+
    2023-10-21
    golang
  • Java高并发下的流量控制方法是什么
    今天小编给大家分享一下Java高并发下的流量控制方法是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。这个时候如果不做任何...
    99+
    2023-06-16
  • mysql多进程并发读取数据的方法是什么
    MySQL是一个单进程应用程序,但可以通过多线程来实现并发读取数据。以下是一些常见的方法:1. 使用连接池:建立一个连接池,多个线程...
    99+
    2023-08-23
    mysql
  • mysql多条件排序的实现方法是什么
    MySQL中可以使用ORDER BY子句来实现多条件排序。ORDER BY子句可以接受多个排序条件,每个条件可以是升序(ASC)或降...
    99+
    2023-08-25
    mysql
  • vue权限控制与管理的实现方法是什么
    本篇内容介绍了“vue权限控制与管理的实现方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、 菜单权限菜单权限:控制用户在系统中能...
    99+
    2023-07-05
  • Unix下PHP并发编程算法的实现方法是什么?
    Unix下PHP并发编程算法的实现方法是什么? 在现代互联网应用中,高并发访问是一个常见的需求。而Unix下PHP并发编程算法的实现方法就是通过使用多进程或多线程的方式实现。下面我们将详细介绍如何使用PHP实现Unix下的并发编程算法。 一...
    99+
    2023-08-13
    unix 并发 编程算法
  • Vue实现自动检测及版本更新的方法是什么
    这篇“Vue实现自动检测及版本更新的方法是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue实现自动检测及版本更新的方...
    99+
    2023-07-05
  • JDBC连接MySQL并实现模糊查询的方法是什么
    这篇文章主要讲解了“JDBC连接MySQL并实现模糊查询的方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JDBC连接MySQL并实现模糊查询的方法是什么”吧!场景:在学习JDBC的...
    99+
    2023-06-22
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作