mysql innodb 文件相关的三个重要结构体
这篇讲的是 MySQL InnoDB 引擎里三个关键的物理结构体——数据页、undo日志页和插入缓冲页。它们虽然都以 16KB 的统一页面格式存储在磁盘文件中,但头部的二进制结构和核心职责却大不相同。 作者从 InnoDB 最小的磁盘 I/O 单位“页”出发,拆解了它们的设计。数据页是存储行数据的“仓库货架”,页头详细记录了校验和、记录数、空闲指针等元信息。undo日志页则像“事务的草稿纸”,专门存放数据被修改前的版本,为回滚和 MVCC 服务。而插入缓冲页是一个临时“集结点”,负责批量合并多个非唯一二级索引的插入操作,以减少随机 I/O。 这三个结构体的区分设计很巧妙:它们共享了通用的页面框架(如校验和、页类型标识),但在头部结构和数据区布局上各司其职。理解这种“同形不同职”的差异,能让我们更清晰地看到 InnoDB 如何在统一的文件架构下,高效地兼顾了数据存储、事务一致性和索引写入性能。这为深入理解数据库底层如何运作提供了很好的视角。