MySQL表空间

2022/6/27 2:20:14

本文主要是介绍MySQL表空间,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

记录下MySQL的表空间。

在MySQL官方文档中,很多行(row)记录在页(page)中,页记录在区(extent)中,区记录在段(segment)中,段则在表空间中。表空间就是tablespace。

 

其中,区是最小的空间申请单位,通常一次性申请4个区。区的固定大小是1M。以MySQL默认的16k页(innodb_page_size)大小为例,一个区就有64个页。另外,如果你设置页大小为32k和64k,区大小会变成2M和4M。

这个参数设小,比如说4k。缺点就是会增加IO,b+树高度会增高。目前的趋势是趋向于宽表,单行会很大,很多你一行数据就1k了。数据再多就涉及行外存了。我是觉得16K就挺不错。

 

 

页则是最小的IO操作单位。

默认是16k。除非你压缩表。MySQL的压缩表是基于页的。看看你表的row_format是不是compressed,key_block_size就是压缩后的页大小。这个也不是页越小,表大小越好。这个它的压缩算法有关。没记错是用得zlib。比如说你要压成8k。他会尝试把你页压缩到8k,能压下来,那就成功。如果只压缩到16k,那么从内存往磁盘写的时候,会分裂成2个8k的页。等于没变。

 

 

未完待续。



这篇关于MySQL表空间的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程