Page是MySQL Innodb存储的最基本结构,也是Innodb磁盘管理的最小单位,了解page的一些特性,可以更容易理解MySQL。
由上图可见表的组成 TableSpace -> Segment -> Extent(固定大小64Page) -> Page . 当Tablespace 小于32M时候一次扩增一个Extent 当 大于32M的时候一次扩增4个Extent .Page是表空间的最小单位默认大小为16KB (Linux 的page大小为4KB)MYSQL5.7 后增加了对Page Size 的设置 32KB 64KB 但是在这一模式下不支持 ROW_FORMAT= compression。(行压缩模式)
innodb_page_size=32k,区段大小为2MB。对于innodb_page_size=64KB,区段大小为4MB。当使用32KB或64KB的页面大小时,innodb_log_buffer_size应该至少设置为16M(默认)。
MySQL内部不会真正删除空间,而且做标记删除,即将delflag:N修改为delflag:Y,commit之后会会被purge进入删除链表,如果下一次insert更大的记录,delete之后的空间不会被重用,如果插入的记录小于等于delete的记录空会被重用,这块内容可以通过知数堂的innblock工具进行分析。
通过从InnoDB存储空间分布,delete对性能的影响可以看到,delete物理删除既不能释放磁盘空间,而且会产生大量的碎片,导致索引频繁分裂,影响SQL执行计划的稳定性;
同时在碎片回收时,会耗用大量的CPU,磁盘空间,影响表上正常的DML操作。