游乐游手机版
首页/科技数码/文章详情

解密MySQL中Redo Log与Undo Log的区别及适用场景

时间:2025-12-02 21:39
MVCC 中文名称叫多版本并发控制,是InnoDB 引擎为了提高执行事务的并发效率引入的概念。多版本的含义就是一条数据被多个事务修改后,在事务还没有被提交前,存在多个版本。MVCC 的实现机制就是通

MVCC的中文名称是多版本并发控制,它是InnoDB存储引擎为提高事务处理效率而引入的重要机制。多版本的意义在于:当一行数据被多个事务陆续修改,只要这些事务尚未提交,该数据就同时存在多个历史版本。MVCC通过版本链将这些不同时间点的数据状态以指针方式串联起来。

大家好,我是君哥。祝大家国庆节快乐!

MySQL拥有三大核心日志体系:Redo Log、Undo Log和Binlog,其中Undo Log和Redo Log都属于InnoDB存储引擎的特有日志。今天我们就来深入剖析Redo Log与Undo Log的本质区别。

1.Undo Log

1.1 MVCC

多版本并发控制(MVCC)是InnoDB引擎实现高并发事务处理的关键技术。其核心思想是:在事务提交前,每个数据修改都会保留历史快照,形成一条版本链。MVCC的实现机制正是通过版本链将多个数据版本有机串联。

以库存表为例,假设记录商品编号为10的初始库存量为100。当事务一将其修改为98,事务二又将其更新为95。

在事务一修改前,InnoDB会先将stock_count=100的原始记录保存至Undo Log,修改后的版本会保留指向原始Undo Log的指针。同样,事务二在修改前会将事务一修改后的记录(stock_count=98)存入新的Undo Log,并将当前记录指向这个新增的Undo Log记录。这样,对同一行数据的连续修改就构成了版本链,如下图所示:

图片图片

为实现版本链结构,InnoDB引擎在每行记录中内置了3个隐藏字段:

DB_TRX_ID:记录执行修改(插入、更新或删除)操作的事务ID;DB_ROLL_PTR:回滚指针,即指向上一历史版本的指针,用于实现事务回滚;DB_ROW_ID:当表未定义主键时自动生成的主键,用于创建聚簇索引。

1.2 Undo Log

在InnoDB中,事务为保障原子性,需要支持完整的事务回滚操作,这就要求记录数据被修改前的状态(比如插入或删除记录,更新记录值),记录这些修改前状态的日志就是Undo Log。

Undo Log主要承担三大核心功能:

原子性:通过Undo Log实现事务回滚,确保操作原子性;一致性:其他事务在进行一致性读取时,可从Undo Log中获取未被修改的原始数据;MVCC:多版本并发控制中的多个数据版本,正是通过Undo Log记录实现的。

Undo Log存储在undo log segments中,而这些段又存放在回滚段(Rollback Segment)。回滚段则分布在undo表空间和全局临时表空间。

图片图片

回滚段支持的事务数量取决于其能容纳的undo slot数量以及每个事务所需要的undo slot数量。在页面大小为16KB的InnoDB引擎中,每个回滚段可保存1024个undo slot。

每个事务只能使用一个回滚段,但同一个回滚段可以同时服务多个事务。

那么Undo Log何时会被清理呢?需要同时满足两个条件:事务已提交,且Undo Log已过期(即保存时间超过undo retention参数指定的时长)。

当然,即使达到清理条件,也不会立即清除,因为Undo Log所在的回滚段页面可能还被其他未提交事务使用(数据页使用率未达3/4)。

对于insert操作产生的Undo Log,由于只对本事务可见,因此事务提交后即可立即删除。而对于update和delete操作,由于可能涉及MVCC版本链的使用,不能在事务提交后立即清理。

当Undo Log满足删除条件时,会放入待清理队列,等待后台purge线程执行删除。

2.Redo Log

Redo Log同样是InnoDB存储引擎特有的日志,它作为物理日志,记录了在数据页上执行的具体修改操作,主要用于崩溃恢复。

2.1 写日志

在日志写入方面,Redo Log采用循环写入机制,空间大小固定,写满后会覆盖之前的日志记录。

Redo Log采用固定大小的文件组配置,如下图所示配置了4个文件,每个文件大小相同,写满一个后继续写下一个,全部写满后就会清理部分早期日志,继续写入新的日志记录。write pos控制当前写入位置,check point控制可以写入的最后位置,如果两点重合,就需要清理部分日志,让check point向后移动。

图片图片

2.2 崩溃恢复

Redo Log的核心作用在于崩溃恢复。它确保了数据库宕机后,已提交事务的数据不会丢失。Redo Log基于WAL(预写日志)原则,即先写日志,再写磁盘。事务提交时,先将修改内容记录到Redo Log,MySQL重启后,利用Redo Log进行崩溃恢复。恢复过程如下图:

图片图片

首先,InnoDB会检查数据页的LSN(日志序列号),并与Redo Log中的LSN进行比对。Redo Log中LSN大于数据页的部分就是需要重做的数据。接着,InnoDB会扫描Redo Log中的待恢复记录,如果日志状态为COMMIT,则直接重做。如果日志状态为PREPARE,还需要检查对应的Binlog,如果该事务的Binlog存在且完整,说明事务已经提交成功,应该重做。如果该事务的Binlog不存在或不完整,说明事务应该回滚,Redo Log记录不需重做。

通过这一机制,确保了Redo Log和Binlog的逻辑一致性:只要Binlog写入成功,数据就一定能够被恢复;如果Binlog没有写入成功,说明事务应该被回滚,数据无需恢复。

3.区别

总结Undo Log与Redo Log的核心区别如下:

最后,我们以下面的SQL为例,来看一下记录日志的完整过程:

update tb_stock set stock_count = 98 where goods_no = 10;

图片图片

来源:https://www.51cto.com/article/826699.html
上一篇YouTube推自愿离职计划 优化产品团队布局促增长 下一篇神舟二十一乘组亮相:32岁武飞成中国最年轻航天员
本站内容用于信息整理与展示,如有侵权或内容问题请及时联系处理。

相关推荐

补充同频道和同主题内容,方便继续浏览更多相关内容。

同类最新

继续查看同栏目最近更新的文章。

更多
宫本茂亲签3DS XL拍卖价破两万美元
科技数码 · 2026-05-29

宫本茂亲签3DS XL拍卖价破两万美元

今天来说一件挺有意思的事:2015年任天堂世界锦标赛冠军约翰·戈德堡,近日将他当年夺冠时赢得的宫本茂亲笔签名版3DS XL掌机放上了拍卖平台。截至2026年5月29日,这台签名掌机的竞拍价已突破两万美元,并且价格还在持续攀升。戈德堡在社交媒体上发布声明表示,经过相当长时间的慎重考虑,他决定将这台对自

七彩虹隐星P16 Pro游戏本新配置仅售7799元
科技数码 · 2026-05-29

七彩虹隐星P16 Pro游戏本新配置仅售7799元

七彩虹近期推出隐星P16Pro游戏本新配置,售价7799元。其搭载酷睿i9-13900HX处理器与RTX5060显卡,配备16英寸2 5K高刷电竞屏及高效散热系统。存储组合为16GB内存与1TB固态硬盘,支持后续扩展。该配置主打高性能性价比,适合预算有限但追求强劲性能的游戏玩家与轻度创作者。

苹果iPhone Hikawa握把支架448元重新上架
科技数码 · 2026-05-29

苹果iPhone Hikawa握把支架448元重新上架

苹果公司重新上架了与艺术家贝利·桧川及PopSockets合作设计的iPhone专用握把支架。该配件采用磁吸设计,兼具握持与支架功能,旨在通过人性化设计降低握持负担,并提供三种配色可选,售价448元。

苹果体育应用扩展至170市场 为2026世界杯引入对阵图
科技数码 · 2026-05-29

苹果体育应用扩展至170市场 为2026世界杯引入对阵图

苹果体育应用新增覆盖90多个国家和地区,全球可用市场总数超过170个。为迎接2026年世界杯,应用加入了完整的赛程对阵图和可视化阵型卡片,方便用户追踪赛事与战术。同时,应用支持实时活动功能,可将比分固定在锁屏或表盘,并新增一键跳转至新闻的入口。目前该应用仍仅限iPhone用户使用。

小米史上最强国产巅峰芯片玄戒O3 6月台积电3nm投产
科技数码 · 2026-05-29

小米史上最强国产巅峰芯片玄戒O3 6月台积电3nm投产

据博主爆料,小米下一代自研玄戒芯片计划于今年6月正式进入量产阶段,此次将采用台积电3nm工艺。初代玄戒O1累计出货量已突破100万颗,量产验证十分扎实。新一代芯片的产能将显著提升,这意味着供货问题基本得到解决。 根据现有曝光信息,这颗迭代芯片极有可能命名为玄戒O3,首发搭载机型预计为小米MIX Fo