mysql undo redo buffer pool

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.执行流程图

MySQL不会丢失数据的秘密,就藏在它的 7种日志里

看上图 我们可以知道其实是有两条线路的,

第一条线路是从bufferpool->通过线程想磁盘刷数据。(正常流程) 未提交的数据也可能会刷到磁盘。

第二条线路:从buffer pool->写入redo log buffer ->redo 日志。

数据的事务提交之后才会写入到binlog中,其中binlog 是数据库层面的,而undo 和redo日志是存储引擎层面的

3.redo buffer 日志的刷盘

MySQL不会丢失数据的秘密,就藏在它的 7种日志里

其中write pos代表的是数据写到的位置。

check point:代表的是已经 落盘之后的位置LSN。叫做check point。

4.double write

    当我们把数据从从bufferpool 写到磁盘的时候,其实是先写入到write buffer,因为写到write buffer是顺序IO的。所以其速度会很快。这么做的目的是为了由于mysql的数据是按也存储的。每页16k,而当进行IO的时候,可能会出现处理了10K,然后就宕机了。我们就无法通过残缺的也找到对应的checknum了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值