0

0

MySQL Redo与Undo日志是什么

WBOY

WBOY

发布时间:2023-05-30 16:07:31

|

2062人浏览过

|

来源于亿速云

转载

    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日志文件中,并且日志文件是循环写入的

    MySQL Redo与Undo日志是什么

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

    • 用户线程的操作会首先写进log buffer

    • log buffer中的日志会顺序写入Redo逻辑日志中

    • 之后会落盘持久化存储到磁盘上

    • 之后通知用户已经存储完成了

    3. Checkpoint机制

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

    • 维护Redo日志,方便清理

    • 减小重启的工作量

      知了追踪
      知了追踪

      AI智能信息助手,智能追踪你的兴趣资讯

      下载

    MySQL Redo与Undo日志是什么

    数据库恢复流程:

    • 读取 checkpoint 信息•从 checkpoint 位置开始读取剩余日志

    • 解析日志并按 space_no 与 page_id 构建 hash 表

    • 应用 Redo 日志,Redo日志回放保证幂等性

    • 解析 binlog 构建 xid 列表

    • 扫描回滚段构建待提交事务列表

    • 回滚掉未在 xid 列表中的事务

    4. Undo日志介绍

    The Undo log is a logical log that records the incremental changes of data, and its function is to ensure the atomicity of transactions and transaction concurrency control. Rewritten: The Undo log serves to guarantee the atomicity of transactions and control their concurrency by logging the incremental changes in data, functioning as a logical log.。它可以用于回滚事务,实现多版本控制(MVCC),并解决读写冲突和一致性读取的问题。

    5. MVCC

    MVCC的意义:

    • 读写互不阻塞;

    • 降低死锁概率;

    • 实现一致性读。

    UndoLog在MVCC的作用:

    • 每个事务有一个单增的事务ID;

    • 数据页的行记录中包含了DB_ROW_ID,DB_TRX_ID,DB_ROLL_PTR;

    • DB_ROLL_PTR将数据行的所有快照记录都通过链表的结构串联了起来。

    相关专题

    更多
    mysql修改数据表名
    mysql修改数据表名

    MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

    652

    2023.06.20

    MySQL创建存储过程
    MySQL创建存储过程

    存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

    244

    2023.06.21

    mongodb和mysql的区别
    mongodb和mysql的区别

    mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

    279

    2023.07.18

    mysql密码忘了怎么查看
    mysql密码忘了怎么查看

    MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

    513

    2023.07.19

    mysql创建数据库
    mysql创建数据库

    MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

    250

    2023.07.25

    mysql默认事务隔离级别
    mysql默认事务隔离级别

    MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

    384

    2023.08.08

    sqlserver和mysql区别
    sqlserver和mysql区别

    SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

    522

    2023.08.11

    mysql忘记密码
    mysql忘记密码

    MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

    594

    2023.08.14

    ip地址修改教程大全
    ip地址修改教程大全

    本专题整合了ip地址修改教程大全,阅读下面的文章自行寻找合适的解决教程。

    27

    2025.12.26

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    MySQL 教程
    MySQL 教程

    共48课时 | 1.5万人学习

    MySQL 初学入门(mosh老师)
    MySQL 初学入门(mosh老师)

    共3课时 | 0.3万人学习

    简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信

    共1课时 | 774人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号