码迷,mamicode.com
首页 > 其他好文 > 详细

Redo,Undo,Binlog

时间:2020-01-17 13:59:04      阅读:93      评论:0      收藏:0      [点我收藏+]

标签:如何   sql 语句   MIXED   www   mvc   内存数据   进制   copy   是什么   

https://www.jianshu.com/p/d829df873332

https://www.jianshu.com/p/57c510f4ec28

 

对于面向disk的数据库,

需要把数据先写入到page中,然后成批的flush到磁盘,所以在Page没有flush前需要有log能记录下page的state

这就是Redo,所以Redo是物理的,因为记录的是Page的具体变更,用Redo的目的是恢复出之前的page

 

Redo本身也是要写disk,每个操作去写也不合适,所以Redo也有个buffer,在事务commit的时候才把Redo顺序写入disk

技术图片

 

 

如果事务已经写入到磁盘,或者对于大事务,可能无法等到commit的时候再flush,这个时候需要rollback

rollback的时候,是需要恢复row的状态,这就需要undo,记录下row在执行事务前的值是什么,所以undo是逻辑的

因为我们只关心的是,undo后,row的值和原来一样,是不是原来的page,这个无法保证,也不重要

 

至于redo和binlog的区别,我就直接copy上面的了

- 层次不同。redo/undo 是 innodb 引擎层维护的,而 binlog 是 mysql server 层维护的,跟采用何种引擎没有关系,记录的是所有引擎的更新操作的日志记录。
- 记录内容不同。redo/undo 记录的是 每个页/每个数据 的修改情况,属于物理日志+逻辑日志结合的方式(redo log 是物理日志,undo log 是逻辑日志)。binlog 记录的都是事务操作内容,binlog 有三种模式:Statement(基于 SQL 语句的复制)、Row(基于行的复制) 以及 Mixed(混合模式)。不管采用的是什么模式,当然格式是二进制的,
- 记录时机不同。redo/undo 在 事务执行过程中 会不断的写入,而 binlog 是在 事务最终提交前 写入的。binlog 什么时候刷新到磁盘跟参数 sync_binlog 相关

 

对于面向内存的数据库

情况变了,内存数据库没有page cache

那是不是还需要Redo和Undo

内存数据库的问题,内存数据是会丢的,如何保证fail后,可以恢复

所以他也要记录Redo到磁盘,但这里的Redo的概念其实发生了变化,和page无关,所以一般也是逻辑的

Undo,内存数据库一般都是mvcc,所以不用刻意去记录undo

 

Redo,Undo,Binlog

标签:如何   sql 语句   MIXED   www   mvc   内存数据   进制   copy   是什么   

原文地址:https://www.cnblogs.com/fxjwind/p/12205206.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!