InnoDB表空间

一、页面类型

1.1 页面通用部分

File Header :记录页面的一些通用信息

File Trailer :校验页是否完整,保证从内存到磁盘刷新时内容的一致性。

File Header结构:

二、独立表空间结构

2.1 区

2.1.1 区的内存分配

对于16KB的页来说,连续的64个页就是一个区 ,一个区默认占用1MB空间。

2.2.2 区的分类

空闲的区:现在还没有用到这个区中的任何页面。

有剩余空间的碎片区:表示碎片区中还有可用的页面。

没有剩余空间的碎片区:表示碎片区中的所有页面都被使用,没有空闲页面。

附属于某个段的区。每一个索引都可以分为叶子节点段和非叶子节点段,除此之外InnoDB还会另外定义一些。

特殊作用的段,在这些段中的数据量很大时将使用区来作为基本的分配单位。

2.2 段

存放叶子节点的区的集合就算是一个 段 ( segment ),存放非叶 子节点的区的集合也算是一个 段 。也就是说一个索引会生成2个段,一个叶子节点段,一个非叶子节点段。

2.2.2 表空间存储空间分配

1、在刚开始向表中插入数据的时候,段是从某个碎片区以单个页面 为单位来分配存储空间的。

2、当某个段已经占用了32个碎片区页面之后,就会以完整的区为单位来分配存储空间。

2.2.3 区的状态

2.3 XDES Entry

Segment ID (8字节)

每一个段都有一个唯一的编号,用ID表示,此处的 Segment ID 字段表示就是该区所在的段。当然前提是该 区已经被分配给某个段了,不然的话该字段的值没啥意义。

List Node (12字节)

这个部分可以将若干个 XDES Entry 结构串联成一个链表,大家看一下这个 List Node 的结构:

想定位表空间内的某一个位置的话,只需指定页号以及该位置在指定页号中的页内偏移量:

Pre Node Page Number 和 Pre Node Offset 的组合就是指向前一个 XDES Entry 的指针。

Next Node Page Number 和 Next Node Offset 的组合就是指向后一个 XDES Entry的指针。

State (4字节)

字段表明区的状态。可选的值4个,分别是: FREE 、FREE_FRAG、 FULL_FRAG和FSEG

Page State Bitmap (16字节)

这个部分共占用16个字节,也就是128个比特位。一个区默认有64个页,128个比特位被划分为64个部分,每个部分2个比特位,对应区中的一个页。这两个比特位的第一个位表示对应的页是否是空闲的,第二个比特位还没有用。

三、系统表空间

相关推荐
广州智造1 小时前
OptiStruct实例:3D实体转子分析
数据库·人工智能·算法·机器学习·数学建模·3d·性能优化
技术宝哥4 小时前
Redis(2):Redis + Lua为什么可以实现原子性
数据库·redis·lua
学地理的小胖砸5 小时前
【Python 操作 MySQL 数据库】
数据库·python·mysql
dddaidai1236 小时前
Redis解析
数据库·redis·缓存
数据库幼崽6 小时前
MySQL 8.0 OCP 1Z0-908 121-130题
数据库·mysql·ocp
Amctwd6 小时前
【SQL】如何在 SQL 中统计结构化字符串的特征频率
数据库·sql
betazhou6 小时前
基于Linux环境实现Oracle goldengate远程抽取MySQL同步数据到MySQL
linux·数据库·mysql·oracle·ogg
lyrhhhhhhhh7 小时前
Spring 框架 JDBC 模板技术详解
java·数据库·spring
喝醉的小喵8 小时前
【mysql】并发 Insert 的死锁问题 第二弹
数据库·后端·mysql·死锁
付出不多9 小时前
Linux——mysql主从复制与读写分离
数据库·mysql