MySQL中MVCC机制的实现原理

 更新时间:2022年08月10日 09:44:48   作者:亚雷  
这篇文章主要介绍了MySQL中MVCC机制的实现原理,MVCC多版本并发控制,MySQL中一种并发控制的方法,他主要是为了提高数据库的读写性能,用更好的方式去处理读写冲突

前言

MVCC全称为Multi Version Concurrency Control,直译为多版本并发控制,是MySQL中一种并发控制的方法,他主要是为了提高数据库的读写性能,用更好的方式去处理读写冲突。

什么是当前读和快照读?

在讲述MVCC机制实现原理之前,我们先了解一下当前读和快照读

当前读:

其实也很容易理解,当前读指的就是读取的是最新的记录,读取的时候还需要保证其他事务不能修改当前记录,所以会对读取的记录进行加锁处理

例如:select for update 、update、insert、delete这些操作都是当前读

快照读:

而快照读也就是不加锁的select,不过需要注意的是快照读的前提是隔离级别不能是serializable(可串行化),之所以出现快照读,是基于提高并发性能的考虑

其实可以简单理解成MVCC就是为了实现读写冲突的时候不去加锁

MVCC的实现原理

其实在MySQL中每一条记录都会有一些隐藏字段,而在MVCC机制中,用处最大的就是trx_id,roll_pointer分别代表着操作这条记录的事务的事务ID,和回滚指针(指向当前记录行的undo log信息),倘若这条记录没有主键,还包含一个隐含的主键ID

在每一个事务开启之前,都会先从数据库中拿到一个自增的事务ID

对于undo log很明显这就是一个日志文件,记录着insert、update、delete,我们在进行删除的时候,其实innodb引擎并没有真正的删除,其实是将一个记录的一个隐含字段修改了,让我们去搜索的时候搜索不到,所以我们可以知道在undo log中只存在两种日志,一种是insert undo log,一种是update undo log

undo log的作用就是为了保存版本链,而前面我们说的roll_pointer这个字段就是指向的这里

为了保证可见性,当事务发起快照读的时候,就会产生一个Read View(读视图),Read View 保存了当前事务开启时所有活跃的事务列表,或者可以理解为保存了其他事务的ID列表

Read View有几个重要属性:

  • trx_ids:当前系统中活跃的事务ID
  • low_limit_id:目前出现的最大的事务ID+1,也就是下一个将被分配的事务ID
  • up_limit_id:活跃事务列表中最小的id
  • creator_trx_id:当前事务的ID

而对于Read View的可见性规则:

  • 如果访问版本事务id = creator_trx_id 那么证明该事务操作的就是自己修改过的记录
  • 如果访问版本事务id < up_limit_id 那么证明生成该版本的事务已经提交
  • 如果访问版本事务id > low_limit_id,那么表示生成该版本的事务还没有提交不能被访问
  • 如果访问版本事务id > up_limit_id 且 id < low_limit_id,那么判断该事务id是否在活跃列表中,如果在证明还未提交不能被访问,反之亦然

到此这篇关于MySQL中MVCC机制的实现原理的文章就介绍到这了,更多相关MySQL MVCC机制内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • mysql中使用sphinx搜索子域名需注意的问题

    mysql中使用sphinx搜索子域名需注意的问题

    比如搜索jb51.net会把www.jb51.net、jb51.net、sc.jb51.net等都搜索出来
    2013-02-02
  • Mysql中的超时时间设置方式

    Mysql中的超时时间设置方式

    这篇文章主要介绍了Mysql中的超时时间设置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-01-01
  • 深入理解MySQL的数据库引擎的类型

    深入理解MySQL的数据库引擎的类型

    本篇文章是对MySQL的数据库引擎的类型进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • MySQL日期时间类型与字符串互相转换的方法

    MySQL日期时间类型与字符串互相转换的方法

    这篇文章主要介绍了MySQL日期时间类型与字符串互相转换的方法,文中通过代码示例和图文结合的方式给大家讲解的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下
    2024-07-07
  • MySQL制作具有千万条测试数据的测试库的方法

    MySQL制作具有千万条测试数据的测试库的方法

    这篇文章主要介绍了MySQL制作具有千万条测试数据的测试库的方法,帮助大家更好的理解和学习MySQL,感兴趣的朋友可以了解下
    2020-11-11
  • MySql查询中按多个字段排序的方法

    MySql查询中按多个字段排序的方法

    在SQL查询中,经常需要按多个字段对结果进行排序,本文主要介绍了MySql查询中按多个字段排序的方法,具有一定的参考价值,感兴趣的可以了解一下
    2024-03-03
  • Mysql中FIND_IN_SET函数的使用及问题

    Mysql中FIND_IN_SET函数的使用及问题

    FIND_IN_SET函数用于返回字符串str在字符串列表str_list中的位置,本文主要介绍了Mysql中FIND_IN_SET函数的使用及问题,具有一定的参考价值,感兴趣的可以了解一下
    2024-07-07
  • 细谈Mysql的存储过程和存储函数

    细谈Mysql的存储过程和存储函数

    存储函数与存储过程作用类同,不同的是存储过程只能使用CALL语句来调用存储过程,只能用输出变量返回值,而存储函数可以从语句外调用(即通过引用函数名),也能返回标量值。下面小编给大家详细讲一讲
    2019-05-05
  • 浅谈MySQL安装starting the server失败的解决办法

    浅谈MySQL安装starting the server失败的解决办法

    如果电脑是不是第一次安装MySQL,一般会出现报错情况,starting the server失败,通常是因为上次安装的该软件未清除干净,本文就详细的介绍一下解决方法,感兴趣的可以了解一下
    2021-09-09
  • 详解MySQL的慢查询日志和错误日志

    详解MySQL的慢查询日志和错误日志

    这篇文章主要详细介绍了MySQL的慢查询日志和错误日志,文中通过代码示例讲解的非常详细,对大家学习和了解MySQL的慢查询日志和错误日志有一定的帮助,需要的朋友可以参考下
    2024-04-04

最新评论