MySQL8.0学习记录19 - 页区段与表空间

最近一直看到页区段的概念,这里先简单整理一下。

表空间由 段(segment)、区(extent)、页(page)组成。

Page(页)

每个表空间由数据库页组成,它是InnoDB存储引擎磁盘管理的最小单位,文档上的表示是它代表InnoDB任何时候在磁盘(数据文件)和内存(缓冲池)之间传输的数据单位。

MySQL实例中的每个表空间都有相同的页大小。默认情况下,所有表空间的页大小为16KB,页大小可以通过innodb_page_size指定。

一般情况下,一页可以包含一行或多行,如果一行数据不能完全容纳在一页中,InnoDB会设置额外的指针式数据结构,这样关于该行的信息就可以存储在一页中。

当InnoDB为了提高I/O吞吐量而批量读取或写入页集合的时候,它会一次读取或写入一个区(extent )。

Extent(区)

区由一组页组成。有的资料提到区有64个页组成,这个不是完全正确的。在MySQL 5.6中,InnoDB实例的页面大小可以是4KB、8KB或16KB,而对于 4KB, 8KB和16KB大小的页来说, 一个区的大小总是 1MB。默认情况下innodb_page_size =16KB,刚好是64个页,组成一个区。从MySQL5.7开始,支持页大小为32KB或64KB,对应的区大小是2M或4M,也是由64个页组成。

区内一组页也是连续的

Segment(段)

段是逻辑概念上的划分,它不要求空间是连续的。段的作用是为了区分不同功能的区,比如对于索引来说,索引的非叶子节点与叶子节点分别存在索引段和数据段。另外,表空间一般还有回滚段。

目前看到的资料,一般认为一段有265个区。

碎片区

在表空间中,还有个不属于任何段的碎片区。碎片区直属于表空间,但所有的段都可以使用。碎片区的提出是为了节省资源,不是每次操作都需要一个完整的区(默认1M)。这时候会先使用碎片区中的页,等使用的页达到或超过32页时,会在段上分配专属的区。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值