一、双写缓冲区 ( Doublewrite Buffer Files)
1.1 背景介绍
写失效 (部分页失效)
- InnoDB的页和操作系统的页大小不一致,InnoDB页大小一般为16K,操作系统页大小为4K,InnoDB的页写入到磁盘时,一个页需要分4次写。
- 如果存储引擎正在写入页的数据到磁盘时发生了宕机,可能出现页只写了一部分的情况,比如只写了4K,就宕机了,这种情况叫做部分写失效(partial page write),可能会导致数据丢失。

1.2 双写缓冲区 Doublewrite Buffer
为了解决写失效问题,InnoDB实现了双写缓冲区,它位于系统表空间,是一个存储区域。
在BufferPool的页刷新到磁盘真正位置前,数据会先被存储在双写缓冲区。
这样在宕机重启时,即使发生数据页损坏,可以通过该页的副本来还原该页,然后再进行redo log重做,确保了数据页的可靠性。
1.3 配置开关
默认情况下启用双写缓冲区,可以通过将 innodb_doublewrite 设置为0 来禁用。
mysql> show variables

最低0.47元/天 解锁文章
1304

被折叠的 条评论
为什么被折叠?



