MySQL中MTR的概念

 更新时间:2020年11月10日 10:45:39   作者:AsiaYe  
这篇文章主要介绍了MySQL中MTR的概念,帮助大家更好的理解和使用MySQL数据库,感兴趣的朋友可以了解下

    MTR全称是Mini-Transaction,顾名思义,可以理解为"最小的事务",MySQL中把对底层页面的一次原子访问的过程称之为一个Mini-Transaction,这里的原子操作,指的是要么全部成功,要么全部失败,不存在中间状态。

    MTR主要是被用在写undo log和redo log的场景下的。例如,我们要向一个B+树索引中插入一条记录,此时要么插入成功,要么插入失败,这个过程就可以称为一个MTR过程,这个过程中会产生一组redo log日志,这组日志在做MySQL的崩溃恢复的时候,是一个不可分割的整体。

    假如我们有一个事务,事务中包含3条语句,那么MTR的概念图如下:

Mini-Transaction一般遵循三条原则:

  • 1、the fix rules
  • 2、WAL
  • 3、force-log-at-commit

这里我们解释下这三条原则:

1、the fix rules

解释第一条规则之前,我们有必要了解下MySQL中的latch的概念,在MySQL中,latch是一种轻量级的锁,与lock不同,它锁定的时间特别短,在innodb中,latch又可以分为mutex(互斥量)和rwlock(读写锁)2种,它的目的在于保证并发线程操作临界资源的正确性。

理解了latch的概念,我们看看the fix rule规则:

修改一个数据页,需要获得这个数据页的x-latch;

访问一个页是需要获得s-latch或者x-latch;

持有该页的latch直到修改或者访问该页的操作完成才释放

2、WAL

WAL技术想必大家比较熟悉,它是Innodb存储引擎之所以支持崩溃恢复的根本,也就是持久化一个数据页之前,需要将内存中响应的日志页先持久化

3、force-log-at-commit

这条原则比较重要,它是指在事务提交的时候,其产生的所有MTR日志都要刷到持久化设备中,从而保证崩溃恢复的逻辑。

   之所以介绍MTR,是为了后续介绍MySQL8.0的redo log 优化做准备,在MySQL5.7中,mtr保证了事务内部操作的原子性。当用户进行操作的时候,会更新数据页,同时写redo log,mtr是redo log的载体,存在每个连接会话的私有变量中。当mtr提交时,会将本地redo log拷贝到全局的log_buffer中,为了保证redo log的有序性,需要加锁来访问log_buffer,这把锁就是上面提到的mutex,在这个锁保护下,除了要将本地日志拷贝到全局buffer,还需要将数据页加入了flush_list,供后台线程刷脏,辅助数据库检查点持续往前推进,所以这个锁在旧版本的MySQL中竞争非常激烈。MySQL8.0将这个问题进行了优化,后面的文章中将着重分析。

以上就是MySQL中MTR的概念的详细内容,更多关于MySQL MTR的资料请关注脚本之家其它相关文章!

相关文章

  • 通过代码实例了解页面置换算法原理

    通过代码实例了解页面置换算法原理

    这篇文章主要介绍了通过代码实例了解页面置换算法原理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-08-08
  • MySQL亿级数据平滑迁移双写方案实战

    MySQL亿级数据平滑迁移双写方案实战

    预约业务与其他业务数据表存储在同一个数据库,当其他业务出现慢SQL等异常时,会影响到预约业务,为了提高系统稳定性和数据隔离性,需要将预约数据表从原来的数据库中迁移出来,单独建立数据库,涉及到的读写场景多,改造成本大,采用 Mybatis插件实现迁移所需的双写等功能
    2024-08-08
  • MySQL 元数据锁及问题排查的解决

    MySQL 元数据锁及问题排查的解决

    MySQL中的元数据锁主要用于管理并发操作下的数据字典一致性,本文主要介绍了MySQL 元数据锁及问题排查的解决,具有一定的参考价值,感兴趣的可以了解一下
    2024-09-09
  • MySQL数据库事务transaction示例讲解教程

    MySQL数据库事务transaction示例讲解教程

    这篇文章主要为大家介绍了MySQL数据库事务transaction的示例讲解教程,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步
    2021-10-10
  • MySQL是怎么保证主备一致的

    MySQL是怎么保证主备一致的

    大家知道 binlog 可以用来归档,也可以用来做主备同步,但它的内容是什么样的呢?为什么备库执行了 binlog 就可以跟主库保持一致了呢,本文就详细的介绍一下
    2021-09-09
  • MySQL常用的建表、添加字段、修改字段、添加索引SQL语句写法总结

    MySQL常用的建表、添加字段、修改字段、添加索引SQL语句写法总结

    这篇文章主要介绍了MySQL常用的建表、添加字段、修改字段、添加索引SQL语句写法,总结分析了MySQL建表、编码设置、字段添加、索引操作所涉及的SQL语句,需要的朋友可以参考下
    2017-05-05
  • 关于MySQL索引的深入解析

    关于MySQL索引的深入解析

    这篇文章主要给大家介绍了关于MySQL索引的深入解析,文中通过示例代码介绍的非常详细,对大家学习或者使用MySQL具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-11-11
  • master and slave have equal MySQL server ids

    master and slave have equal MySQL server ids

    Fatal error: The slave I/O thread stops because master and slave have equal MySQL server ids
    2013-07-07
  • mysqld-nt: Out of memory (Needed 1677720 bytes)解决方法

    mysqld-nt: Out of memory (Needed 1677720 bytes)解决方法

    这篇文章主要介绍了mysqld-nt: Out of memory (Needed 1677720 bytes)解决方法,需要的朋友可以参考下
    2014-12-12
  • MySQL高效导入多个.sql文件方法详解

    MySQL高效导入多个.sql文件方法详解

    MySQL有多种方法导入多个.sql文件,常用的有两个命令:mysql和source,如何提高导入速度,在导入大的sql文件时,建议使用mysql命令
    2018-10-10

最新评论