关于 InnoDB 起始段大小的疑问

2018-02-10 15:34:59 +08:00
 flowarmor

《 MySQL 技术内幕:InnoDB 存储引擎》上看到的内容,有点疑惑。

区的大小肯定是 1MB,在启用 innodb_file_per_table 后,表文件的大小不是 1MB 而是 96KB,是因为在每个段开始时是先用 32 个页大小的碎片页存放数据的。那按照页大小 16KB 的情况理解,起始段大小不应该是 16KB*32=512KB 吗,这个 96KB 是怎么回事呢?

望知道的朋友不吝赐教,非常感谢。

1947 次点击
所在节点    程序员
1 条回复
sryanyuan
2018-05-09 16:56:23 +08:00
表空间文件刚创建的时候 初始大小是 96KB 一共有 6 页
page 0 是 file space header,用户管理 extend 信息,一共可以管理 512 个 extend(512M),假设多了,那么会在后续多一个 extend descriptor
page 1 是 insert buffer bitmap
page 2 是 file segment inode,用于管理 segment 的
剩下 3 页都是空闲页

当创建表并添加一条记录的时候,page 3 会作为 leaf node 存储数据,此时会占用 2 个 inode (假设只有 1 个 primary key 和作为索引),一个用于记录 leaf 的 extend 信息,一个用于记录 non-leaf 的 extend 信息,在这里该 page 既是 leaf 也是 non-leaf。

在从 segment 分配 page 的时候,首先会去空闲页中寻找可用的空闲页,存入 inode 的尺寸为 32 的碎片页数组,当该数组满的时候,会单独分配 1 个 extend。

所以这本书上说的 32 个页的碎片页,不是指实际分配的碎片页,指的是当一个新表创建后,首先分配的是碎片页,当分配了 32 个碎片页之后,才会分配单独的完整的 extend,当然该 extend 会被记录到 inode 中。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/430007

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX