Undo Log 属于逻辑日志,记录一个变化过程。执行一个delete会记录一个相反的insert;它是在数据库事务开始之前,将要修改的记录存放到Undo Log里,当事务回滚或数据库崩溃时利用Undo Log日志,撤销未提交事务对数据库产生的影响。
Undo Log在事务开始前产生;事务在提交时,并不会立即删除Undo Log,InnoDB 会将该事务对应的Undo Log放到删除列表中,后面会通过后台线程purge thread进行回收处理
Undo Log是为了实现事务的原子性而出现的产物。事务处理过程中,如果出现了错误或者用户执行了Rollback语句,mysql可以利用Undo Log中的备份将数据恢复到事务开始之前的状态。
Undo Log在Mysql InnoDB 存储引擎中用来实现MVCC。事务未提交前,Undo Log保存了未提交之前的版本数据,Undo Log中的数据可作为数据旧版本快照供其他并发事务进行快照读。
Redo Log是InnoDB 引擎所特有的日志,以恢复操作为目的,在数据库发生意外时重现操作。Redo Log文件内容是以顺序循环的方式写入文件,写满时则回溯到第一个文件,进行覆盖写。
Redo Log是为了实现事务的持久性而出现的产物。防止在发生故障的时间点,尚有脏页未写入表的idb文件中,在重启mysql服务的时候,根据Redo Log进行重做,从而达到事务的未入磁盘数据进行持久化这一特性。
Binlog 是记录所有数据库表结构变更和表数据修改的二进制日志,不会记录select和show这类操作。Binlog 是以事件形式记录,还包含了语句所执行的消耗时间。
开启Binlog有以下两个最重要的使用场景: