博客
关于我
MySQL原理简介—7.redo日志的底层原理
阅读量:789 次
发布时间:2023-02-12

本文共 1630 字,大约阅读时间需要 5 分钟。

MySQL Redo Log和Undo Log深入解析

MySQL中的Redo Log和Undo Log是数据库事务管理中的关键机制,确保数据的持久性和事务的原子性。了解它们的工作原理对于数据库的高效运行至关重要。本文将从Redo Log的作用、结构及写入机制,到Undo Log的功能以及两者之间的区别进行详细分析。

1. Redo Log的作用

(1)防止事务提交后数据丢失

在数据库环境中,当一个事务提交后,如果系统突然崩溃,缓存页尚未刷入磁盘,数据可能丢失。Redo Log通过记录事务提交时的修改操作,确保在系统恢复时能够恢复这些修改。

(2)事务提交时的数据记录

每当一个事务提交时,MySQL会将事务对数据库的所有修改记录到Redo Log中。这些记录不仅包括修改的数据页,还包括修改的偏移量和具体的修改值。这样,即使系统在事务提交后崩溃,也可以通过重放Redo Log来恢复修改。

(3)缓存页刷盘与Redo Log刷盘的区别

  • 缓存页刷盘:将修改过的缓存页直接刷入磁盘。这会涉及大量随机写操作,影响性能。
  • Redo Log刷盘:将修改记录写入Redo Log文件中。由于每条记录仅几十字节,且采用顺序写,性能显著提升。

2. Redo Log的结构与写入机制

(1)Redo Log的组成

  • 表空间ID:标识受影响的表空间。
  • 数据页号:指明修改的数据页。
  • 偏移量:指明修改的起始位置。
  • 修改字节数:表明需要修改的字节数。
  • 具体修改值:记录修改的具体数据。

(2)Redo Log Block的结构

  • Header(12字节):包含块编号、数据长度、Redo Log组ID和检查点编号。
  • Body(496字节):存储实际的Redo Log记录。
  • Trailer(4字节):用于校验和同步。

(3)Redo Log的写入

  • Redo Log记录先进入内存中的Redo Log Buffer,填充到一个512字节的Redo Log Block。
  • 当Buffer满时,将整个Redo Log Block一次性写入磁盘文件。写入采用顺序写,提升性能。

3. Redo Log Buffer的工作原理

(1)Redo Log Buffer的大小

默认为16MB,足够存储大量Redo Log记录。每个Redo Log Block仅512字节,写入速度快。

(2)Redo Log Buffer的刷盘时机

  • 基于使用情况:当Buffer已使用过半时,系统会将部分或全部Redo Log刷入磁盘。
  • 事务提交:在每次事务提交时,系统会刷盘确保数据持久性。
  • 后台线程:定期刷盘,维持数据库的稳定性。
  • 系统关闭:在MySQL关闭时,系统会将所有未刷入磁盘的Redo Log记录刷入磁盘。

4. Undo Log的作用与结构

(1)Undo Log的场景

  • 事务回滚:在事务执行过程中,由于部分操作未完成,需要回滚,Undo Log提供恢复的数据点。
  • 事务恢复:允许在崩溃后恢复未完成的事务。

(2)Undo Log记录内容

  • 主键信息:记录插入、更新、删除操作的主键值。
  • 回滚操作:为每种操作提供逆操作,例如插入的回滚是删除,删除的回滚是插入。

5. Undo Log与Redo Log的区别

(1)作用不同

  • Redo Log:防止事务提交后数据丢失,确保数据持久性。
  • Undo Log:支持事务回滚,保证事务的原子性和一致性。

(2)日志结构

  • Redo Log:记录事务提交时的修改信息。
  • Undo Log:记录事务操作的逆操作信息。

6. 总结

Redo Log和Undo Log是MySQL事务管理的关键机制。Redo Log通过记录事务提交时的修改,防止数据丢失;而Undo Log通过记录操作的逆操作,支持事务的回滚。两者协同工作,确保了数据库的高效运行和数据的安全性。在实际应用中,合理配置Redo Log和Undo Log参数,可以进一步提升数据库的性能和稳定性。

转载地址:http://zqbfk.baihongyu.com/

你可能感兴趣的文章
MySQL中你必须知道的10件事,1.5万字!
查看>>
MySQL中使用IN()查询到底走不走索引?
查看>>
Mysql中使用存储过程插入decimal和时间数据递增的模拟数据
查看>>
MySql中关于geometry类型的数据_空的时候如何插入处理_需用null_空字符串插入会报错_Cannot get geometry object from dat---MySql工作笔记003
查看>>
mysql中出现Incorrect DECIMAL value: '0' for column '' at row -1错误解决方案
查看>>
mysql中出现Unit mysql.service could not be found 的解决方法
查看>>
mysql中出现update-alternatives: 错误: 候选项路径 /etc/mysql/mysql.cnf 不存在 dpkg: 处理软件包 mysql-server-8.0的解决方法(全)
查看>>
Mysql中各类锁的机制图文详细解析(全)
查看>>
MySQL中地理位置数据扩展geometry的使用心得
查看>>
Mysql中存储引擎简介、修改、查询、选择
查看>>
Mysql中存储过程、存储函数、自定义函数、变量、流程控制语句、光标/游标、定义条件和处理程序的使用示例
查看>>
mysql中实现rownum,对结果进行排序
查看>>
mysql中对于数据库的基本操作
查看>>
Mysql中常用函数的使用示例
查看>>
MySql中怎样使用case-when实现判断查询结果返回
查看>>
Mysql中怎样使用update更新某列的数据减去指定值
查看>>
Mysql中怎样设置指定ip远程访问连接
查看>>
mysql中数据表的基本操作很难嘛,由这个实验来带你从头走一遍
查看>>
Mysql中文乱码问题完美解决方案
查看>>
mysql中的 +号 和 CONCAT(str1,str2,...)
查看>>