Mysql基础(八):表空间、段、区、页的关系

目录

1、表空间和数据区的概念 

表空间

段(segment)

区(extent)

页(page)

总结


1、表空间和数据区的概念 

表空间

        ​ 从 InnoDB 逻辑存储结构来看,所有的数据都被逻辑的存放在一个空间中,这个空间就叫做表空间(tablespace)。表空间由 段(segment)、区(extent)、页(page)组成。

        ​ 当我们创建一个表之后,在磁盘上会有对应的表名称.ibd的磁盘文件。表空间的磁盘文件里面有很多的数据页,一个数据页最多16kb,因为不可能一个数据页一个磁盘文件,所以数据区的概念引入了。

​         一个数据区对应64个数据页,就是16kb,一个数据区是1mb,256个数据区被划分为一组,对于表空间而言,他的第一组数据区的第一个数据区的前3个数据页,都是固定的,里面存放了一些描述性的数据。比 如FSP_HDR这个数据页,他里面就存放了表空间和这一组数据区的一些属性。IBUF_BITMAP 数据页,存放的就是insert buffer的信息,INODE 数据页存放的也是特殊信息。

 再次强调一遍:我们平时创建的那些表都是有对 应的表空间的,每个表空间就是对应了磁盘上的数据文件,在表空间里有很多组数据区,一组数据区是256个数据区, 每个数据区包含了64个数据页,是1mb    

段(segment)

​ 段(Segment)分为索引段,数据段,回滚段等。其中索引段就是非叶子结点部分,而数据段就是叶子结点部分,回滚段用于数据的回滚和多版本控制。一个段包含256个区(256M大小)。

​ 一个段包含多少区:256个区

区(extent)

​ 区是页的集合,一个区包含64个连续的页,默认大小为 1MB (64*16K)。

页(page)

​ 页是 InnoDB 管理的最小单位,常见的有 FSP_HDR,INODE, INDEX 等类型。所有页的结构都是一样的,分为文件头(前38字节),页数据和文件尾(后8字节)。页数据根据页的类型不同而不一样。

​ 每个空间都分为多个页,通常每页16 KiB。空间中的每个页面都分配有一个32位整数页码,通常称为“偏移量”(offset),它实际上只是页面与空间开头的偏移量(对于多文件空间,不一定是文件的偏移量)。因此,页面0位于文件偏移量0,页面1位于文件偏移量16384,依此类推。 (InnoDB 的数据限制为64TiB,这实际上是每个空间的限制,这主要是由于页码是32位整数与默认页大小的组合

总结

个人理解:表空间表示一本书,段表示书中的章节,区表示每章节的小节,页表示书的每一页,行就是每页的每行数据。表空间里有多个段,一个段包含256个区,一个区包含64个页,一个页为16K。

  • 8
    点赞
  • 41
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL单表数据大于500万时,需要考虑以下几个方面: 1. 数据库的选型:MySQL是一个开源的关系型数据库管理系统,可以应对大部分的数据存储需求。但是当单表数据超过500万时,需要评估MySQL是否仍然能够满足性能需求,是否需要考虑其他高性能数据库或者分布式数据库方案。 2. 数据库表的设计:优化数据库表结构是提高性能的基础。可以考虑使用合适的数据类型和字长度来节省存储空间,对经常查询的字添加索引,避免使用过多的关联关系等。 3. 数据库索引的优化:合理的索引可以加速查询操作。在单表数据量大的情况下,需要根据实际查询需求,添加合适的索引。注意维护索引的代价和空间占用。 4. 数据分:当单表数据超过500万时,可以考虑将数据进行分存储。根据数据的特性,可以按照日期、地理位置、用户等进行分。分可以提高查询性能,降低数据的维护成本。 5. 数据库服务器的优化:对数据库服务器进行性能优化可以有效提高查询性能。可以考虑调整数据库的缓存设置、线程池大小、网络连接数等参数,以及与硬件资源配套的优化等。 6. 数据备份和容灾:当单表数据量大时,数据备份和容灾变得尤为重要。需要定期进行数据备份,确保数据的安全性。同时可考虑使用数据库复制或者分布式数据库方案来实现高可用和故障恢复。 总之,当MySQL单表数据大于500万时,需要综合考虑数据库的选型、表结构设计、索引优化、数据分、服务器优化、数据备份和容灾等方面,以提高查询性能和数据安全性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值