MySQL Redo与Undo日志详细解析

 更新时间:2022年07月31日 09:32:16   作者:树獭叔叔​​​​​​​  
这篇文章主要介绍了MySQL Redo与Undo日志详细解析,Redo日志是物理日志,记录的是页面的变化,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的朋友可以参考一下

1. Redo日志的介绍

Redo日志是物理日志,记录的是页面的变化。

1.1 Redo日志的作用

  • 提升数据库写入效率
  • 保证数据库不丢数据,进行数据恢复

1.2 Redo日志的格式与类型

所谓REDO的组织方式,就是如何把需要的REDO内容记录到磁盘文件中,以方便高效的REDO写入,读取,恢复以及清理。我们这里把REDO从上到下分为三层:逻辑REDO层、物理REDO层和文件层。

  • 逻辑REDO层

这一层是真正的REDO内容,顺序的数据流,REDO由多个不同Type的多个REDO记录收尾相连组成,有全局唯一的递增的偏移sn,InnoDB会在全局log_sys中维护当前sn的最大值,并在每次写入数据时将sn增加REDO内容长度。

  • 物理REDO层

磁盘是块设备,InnoDB中也用Block的概念来读写数据,一个Block的长度OS_FILE_LOG_BLOCK_SIZE等于磁盘扇区的大小512B,每次IO读写的最小单位都是一个Block。

  • 文件层

最终REDO会被写入到REDO日志文件中,并且日志文件是循环写入的

2. 写入Redo日志的流程(MTR)

  • 用户线程的操作会首先写进log buffer
  • log buffer中的日志会顺序写入Redo逻辑日志中
  • 之后会落盘持久化存储到磁盘上
  • 之后通知用户已经存储完成了

3. Checkpoint机制

Checkpoint是Redo日志中脏页的标记位,有以下两个作用:

  • 维护Redo日志,方便清理
  • 减小重启的工作量

数据库恢复流程:

  • 读取 checkpoint 信息•从 checkpoint 位置开始读取剩余日志
  • 解析日志并按 space_no 与 page_id 构建 hash 表
  • 应用 Redo 日志,Redo日志回放保证幂等性
  • 解析 binlog 构建 xid 列表
  • 扫描回滚段构建待提交事务列表
  • 回滚掉未在 xid 列表中的事务

4. Undo日志介绍

Undo log是逻辑日志,记录的是数据的增量变化,它的作用是保证事务的原子性和事务并发控制。可以用于事务回滚,以及提供多版本机制(MVCC),解决读写冲突和一致性读的问题。

5. MVCC

MVCC的意义:

  • 读写互不阻塞;
  • 降低死锁概率;
  • 实现一致性读。

UndoLog在MVCC的作用:

  • 每个事务有一个单增的事务ID;
  • 数据页的行记录中包含了DB_ROW_ID,DB_TRX_ID,DB_ROLL_PTR;
  • DB_ROLL_PTR将数据行的所有快照记录都通过链表的结构串联了起来。

到此这篇关于MySQL Redo与Undo日志详细解析的文章就介绍到这了,更多相关MySQL Redo与Undo 内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • CentOS下RPM方式安装MySQL5.6教程

    CentOS下RPM方式安装MySQL5.6教程

    这篇文章主要为大家详细介绍了CentOS下RPM方式安装MySQL5.6教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-04-04
  • VS2019连接mysql8.0数据库的教程图文详解

    VS2019连接mysql8.0数据库的教程图文详解

    这篇文章主要介绍了VS2019连接mysql8.0数据库的教程,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-05-05
  • MySQL 数据库跨操作系统的最快迁移方法

    MySQL 数据库跨操作系统的最快迁移方法

    原始的是Windows 2003下的32位的MySQL数据库, 新的服务器是Sun的64位的小型机,64位的MySQL数据库。
    2009-02-02
  • MySQL8.0锁等待排查的实现

    MySQL8.0锁等待排查的实现

    MySQL8.0相较于5.7版本在锁等待排查方面发生了显著变化,原有的INNODB_LOCKS和INNODB_LOCK_WAITS表被移除,本篇文章将结合这些改动,介绍 MySQL 8.0 版本如何排查锁等待问题,感兴趣的可以了解一下
    2024-09-09
  • MySQL服务器连接过程浅析

    MySQL服务器连接过程浅析

    这篇文章主要介绍了MySQL服务器连接过程浅析,本文从源码分析了MySQL服务器的连接过程,需要的朋友可以参考下
    2015-03-03
  • MySQL8.0 如何快速加列

    MySQL8.0 如何快速加列

    这篇文章主要介绍了MySQL8.0 如何快速加列,帮助大家更好的理解和使用MySQL数据库,感兴趣的朋友可以了解下
    2020-09-09
  • MySQL存储引擎总结

    MySQL存储引擎总结

    这篇文章主要介绍了MySQL存储引擎总结,本文讲解了什么是存储引擎、MyISAM、InnoDB、MEMORY、MERGE等内容,需要的朋友可以参考下
    2014-09-09
  • 从MySQL全库备份中恢复某个库和某张表的方法

    从MySQL全库备份中恢复某个库和某张表的方法

    这篇文章主要介绍了从MySQL全库备份中恢复某个库和某张表的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • MySQL建立数据库时字符集与排序规则的选择详解

    MySQL建立数据库时字符集与排序规则的选择详解

    当数据库需要适应不同的语言就需要有不同的字符集,下面这篇文章主要给大家介绍了关于MySQL建立数据库时字符集与排序规则的选择的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-06-06
  • Mysql中雪花算法(Snowflake)的使用

    Mysql中雪花算法(Snowflake)的使用

    雪花算法是一种生成全局唯一ID的分布式算法,本文就来介绍一下Mysql中雪花算法的使用,具有一定的参考价值,感兴趣的可以了解一下
    2025-02-02

最新评论