MySQL的Undo Log、Redo Log和Binlog
创始人
2024-02-13 21:28:33

Undo Log、Redo Log、Binlog三者的理解

Undo Log - 逻辑日志:

Undo Log 属于逻辑日志,记录一个变化过程。执行一个delete会记录一个相反的insert;它是在数据库事务开始之前,将要修改的记录存放到Undo Log里,当事务回滚或数据库崩溃时利用Undo Log日志,撤销未提交事务对数据库产生的影响。

Undo Log在事务开始前产生;事务在提交时,并不会立即删除Undo Log,InnoDB 会将该事务对应的Undo Log放到删除列表中,后面会通过后台线程purge thread进行回收处理

Undo Log作用

  1. 实现事务的原子性

Undo Log是为了实现事务的原子性而出现的产物。事务处理过程中,如果出现了错误或者用户执行了Rollback语句,mysql可以利用Undo Log中的备份将数据恢复到事务开始之前的状态。

  1. 实现多版本并发控制(MVCC)

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

Redo Log - 物理日志:

​ Redo Log是InnoDB 引擎所特有的日志,以恢复操作为目的,在数据库发生意外时重现操作。Redo Log文件内容是以顺序循环的方式写入文件,写满时则回溯到第一个文件,进行覆盖写。

​ Redo Log是为了实现事务的持久性而出现的产物。防止在发生故障的时间点,尚有脏页未写入表的idb文件中,在重启mysql服务的时候,根据Redo Log进行重做,从而达到事务的未入磁盘数据进行持久化这一特性。

Redo Log 有两个指针Write Pos和CheckPoint

  1. Writr Pos是当前记录的位置,一边写一边后移,写到最后一个文件末尾后就回到0号文件开头;
  2. CheckPoint是当前要擦除的位置,也是往后推移并且循环的,擦除数据前要把数据更新到数据文件;
  3. Write Pos和Check Point之间还空着的部分,可以用来记录新的操作。如果Write Pos追上CheckPoint时表示写满,这时就不能再执行新的更新,得停下来先擦掉一些记录,把CheckPoint推进一下。

Binlog (Binary log - 二进制日志)

Binlog 是记录所有数据库表结构变更和表数据修改的二进制日志,不会记录select和show这类操作。Binlog 是以事件形式记录,还包含了语句所执行的消耗时间。

开启Binlog有以下两个最重要的使用场景:

  • 主从复制:在主库开启Binlog功能,这样主库就可以把Binlog传递给从库,从库拿到binlog后实现数据恢复,达到主从数据一致;
  • 数据恢复:通过mysqlbinlog 工具来恢复数据。

Redo Log和Binlog的区别

  1. Redo Log是属于InnoDB 引擎功能,Binlog是属于Mysql Server自带的功能,并且是以二进制文件记录;
  2. Redo Log属于物理日志,记录该数据页更新状态内容;Binlog 是逻辑日志,记录更新过程;
  3. Redo Log日志是循环写,日志空间大小固定;Binlog 是追加写,不会覆盖使用。

相关内容

热门资讯

金帝股份跌0.69%,成交额3... 12月2日,金帝股份跌0.69%,成交额3212.79万元,换手率1.85%,总市值53.62亿元。...
泰鸿万立跌0.76%,成交额1... 12月2日,泰鸿万立跌0.76%,成交额1773.07万元,换手率1.20%,总市值66.89亿元。...
新相微跌0.94%,成交额1.... 12月2日,新相微跌0.94%,成交额1.35亿元,换手率2.10%,总市值92.23亿元。异动分析...
美信科技涨0.31%,成交额4... 12月2日,美信科技涨0.31%,成交额4552.86万元,换手率4.12%,总市值26.47亿元。...
宏工科技跌1.77%,成交额2... 12月2日,宏工科技跌1.77%,成交额2.04亿元,换手率9.67%,总市值101.06亿元。异动...