记录下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的页。等于没变。
未完待续。