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 是追加写,不会覆盖使用。

相关内容

热门资讯

代表委员履职记丨杨新民委员:把... 来源:科技日报科技日报记者 王姗姗在启程参加2026年全国两会前,全国政协委员、重庆国家应用数学中心...
奕派科技双品牌发力:前2月销量... 中经记者 张家振 武汉报道如何打赢“新春第一仗”?奕派科技以全新销量表现给出了自己的答案。3月1日,...
黄金交易提醒:中东战火蔓延推升...   汇通财经APP讯——周一(3月2日)全球黄金市场迎来剧烈波动。在美国与以色列对伊朗发动军事打击后...
价格暴涨!全球LNG格局或将迎... .ct_hqimg {margin: 10px 0;} .hqimg_wrapper {text-a...
美国敦促美公民立即离开中东国家 每经AI快讯,一名美国官员当地时间3月2日透露,美国国务院敦促美国公民立即离开十多个中东国家。美国和...