InnoDB的几个关键特性-Double Write(两次写)

InnoDB可能出现部分失效的问题(比如缓冲池往磁盘刷新脏页时写了部分就宕机了)。一般是通过redo log来恢复,但是redo log记录的是对页的物理操作记录,而不是最新页的数据记录,如果页本身发生损坏了,redo log没用

double write就是在写之前存一个页的副本,doublewrite由两部分组成:

  • 内存中的double write buffer,2MB
  • 磁盘共享表空间连续的128个页,大小2MB
    在对缓冲池的脏页进行刷新时,不直接写磁盘,先通过memcpy把脏页复制到double write buffer,再分两次,每次1MB顺序地写入共享表空间的物理磁盘,然后调用fsync函数同步磁盘,避免缓冲写带来的问题
    在这里插入图片描述
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值