随笔 - 303  文章 - 0  评论 - 3  阅读 - 15万

MySQL架构原理之存储引擎InnoDB_Undo Log

  Undo:意为撤销或取消,以撤销操作为目的,返回某个指定状态的操作。

  Undo Log:数据库事务开始之前会将要修改的记录存放到Undo日志里,当事务回滚时或者数据库崩溃时可以利用Undo日志撤销为提交事务对数据库产生的影响。

  Undo Log产生和销毁:Undo Log在事务开始前产生;事务在提交时,并不会立刻删除undo log, innodb会将该事务对应的undo log放入到删除列表中,后面会通过后台线程purge thread进行回收处理。

    Undo Log 属于逻辑日志,记录一个辨别过程。例如执行一个delete,undolog会记录一个insert;执行一个update,undolog会记录一个相反的update。

  Undo Log存储:undo log采用段的方式管理和记录。在innodb数据文件中包含一种rollback segment回滚段,内部包含1024个undo log segment。可以通过下面一组参数来控制Undo log存储:

    show variables like '%innodb_undo%';

  以上对Undo Log进行了基本的介绍,下面介绍它为何存在,解决什么问题——即它的作用:

  1、实现事务的原子性

    Undo Log 是为了实现事务的原子性而出现的产物。事务处理过程中,如果出现了错误或者用户执行了 ROLLBACK 语句,MySQL 可以利用 Undo Log 中的备份将数据恢复到事务开始之前的状态。
  2、实现多版本并发控制(MVCC

    Undo Log MySQL InnoDB 存储引擎中用来实现多版本并发控制。事务未提交之前,Undo Log保存了未提交之前的版本数据,Undo Log 中的数据可作为数据旧版本快照供其他并发事务进行快照读。

        

    1)事务A手动开启事务,执行更新操作,首先会把更新命中的数据备份到 Undo Buffer 中。

    2)事务B手动开启事务,执行查询操作,会读取 Undo 日志数据返回,进行快照读








                                                                       

  

 

posted on   池塘里洗澡的鸭子  阅读(158)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示