1、介绍
mysql5.7中,innodb页结构增加了一个类型FIL_PAGE_COMPRESSED,用来完成Transparent page compression 特性

2、说明
1)压缩内容包括:除去FIL_PAGE_DATA外所有数据,包括tail
2)压缩后的内容+FIL_PAGE_DATA会以block_size对齐,并将空洞清0。意味着将16K压缩到9K,也需要12KB的数据,因此将block_size设小点,这样的场景将受益,可以
减少空间浪费。
3)FIL_PAGE_VERSION内容存1;FIL_PAGE_ALGORITHM_V1指哪个压缩算法:ZLIB、LZ4
FIL_PAGE_ORIGINAL_TYPE_V1:原始页类型;
FIL_PAGE_ORIGINAL_SIZE_V1:原始页需要压缩的内容大小
FIL_PAGE_COMPRESS_SIZE_V1:内容压缩后大小
4)目前支持2种压缩算法:zlib和lz4,可以方便扩展新的算法
5)压缩只是在持久化磁盘的时候压缩,内存中的页仍然是原始的样子
3、用法
表定义:
可以通过CREATE TABLE、ALTER TABLE来定义压缩表:
create table t1(i int,b blob) compression='zlib';
也可以选择compression='lz4'来指定lz4压缩算法,注意compression属性的ALTER是立即生效,在做完ALTER COMPRESSION属性操作后,需要做一次表的rebuild,例如optimize table操作,才能对已有的数据做punch hole。compression属性存储在frm文件中,以2个字节存储字符串长度,随后存储compression属性定义字符串,这也是一个操作系统降级的风险点。
4、代码分析
点击(此处)折叠或打开
http://mysql.taobao.org/monthly/2015/08/01/
5、参考
http://mysqlserverteam.com/innodb-transparent-page-compression/