1.概念
undo 日志用于恢复。
redo 日志用于重做。
buffer pool:把磁盘的数据加载大buffer pool,修改buffer pool中的数据,并把数据记录到redo log buffer中。
WAL(Write-Ahead Logging):redo log是写之前记录的。我们会把日志写入redo日志,再把数据写入buffer pool.当事务提交的时候 就执行redo log 落盘操作(在此之前会先执行binlog的操作)。redo 落盘了,但是buffer pool 不一定会落盘,其实是通过一个异步的线程去执行落盘操作的。
2.执行流程图
看上图 我们可以知道其实是有两条线路的,
第一条线路是从bufferpool->通过线程想磁盘刷数据。(正常流程) 未提交的数据也可能会刷到磁盘。
第二条线路:从buffer pool->写入redo log buffer ->redo 日志。
数据的事务提交之后才会写入到binlog中,其中binlog 是数据库层面的,而undo 和redo日志是存储引擎层面的
3.redo buffer 日志的刷盘
其中write pos代表的是数据写到的位置。
check point:代表的是已经 落盘之后的位置LSN。叫做check point。
4.double write
当我们把数据从从bufferpool 写到磁盘的时候,其实是先写入到write buffer,因为写到write buffer是顺序IO的。所以其速度会很快。这么做的目的是为了由于mysql的数据是按也存储的。每页16k,而当进行IO的时候,可能会出现处理了10K,然后就宕机了。我们就无法通过残缺的也找到对应的checknum了。