Innodb 事件流程
Doublewrite Buffer
InnoDB 存储引擎的 Doublewrite Buffer(双写缓冲区)是一种用于数据完整性和恢复的关键机制。它是为了在数据库发生崩溃时保护数据不受损坏设计的。下面将详细介绍 Doublewrite Buffer 的工作原理、目的以及其对性能的影响。
前置知识
# 查看操作系统一页的大小 4096=4KB
getconf PAGESIZE
# 查看MySQL一页的大小 16384=16KB
show variables like '%page_zise%'
工作原理
Doublewrite Buffer 的主要目的是防止因部分写入(partial page writes)造成的数据页损坏。在某些情况下,当数据库系统正在写入一个数据页到磁盘的过程中发生崩溃,可能会导致该页只写入了一部分,从而损坏了页的内容。为了解决这个问题