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

相关内容

热门资讯

从试点迈向规模化落地,Clou... 2023年,人工智能迎来技术大爆炸;2024年,行业步入应用落地的探索阶段;2025年,全产业躬身入...
俊裕地基(01757)计划于中... 俊裕地基(01757)发布公告,因应中国民众消费水平提升及人口老化趋势,本集团将积极配合国家政策,计...
中国经济信心说丨奔向中国式现代... 转自:央视新闻客户端一年之计在于春。立春前一天,中央一号文件如期发布。这是党的十八大以来,连续14年...
巴基斯坦首都爆炸事件已致31死... 据央视新闻消息,当地时间6日,一名巴基斯坦官员称,当天早些时候该国首都伊斯兰堡一座清真寺发生的爆炸事...
顺络电子(002138.SZ)... 格隆汇2月6日丨顺络电子(002138.SZ)公布,公司作为有限合伙人与普通合伙人国投创新投资管理有...