您好,欢迎访问一九零五行业门户网

MySQL 5.6 Innodb数据页 16K vs 8K性能对比测试

从mysql5.6开始,一个新参数innodb_page_size可以设置innodb数据页为8k,4k,默认为16k。这个参数在一开始初始化时就要加入my.cnf里,如果已经创建了表,再修改,启动mysql会报错。 参考手册: - 下面我针对16k和8k做了一个压力测试。 硬件:r710,72g内存,6
从mysql5.6开始,一个新参数innodb_page_size可以设置innodb数据页为8k,4k,默认为16k。这个参数在一开始初始化时就要加入my.cnf里,如果已经创建了表,再修改,启动mysql会报错。
参考手册:
-
下面我针对16k和8k做了一个压力测试。
硬件:r710,72g内存,6块300g、15000转做的raid10,xfs分区。
my.cnf参数:
1.innodb_buffer_pool_size = 48g 2.innodb_buffer_pool_instances = 8 3.innodb_flush_method = o_direct 4.innodb_file_per_table = 15.innodb_read_io_threads = 16 6.innodb_write_io_threads = 16 7.innodb_io_capacity = 2000 8.innodb_log_files_in_group = 3 9.innodb_flush_log_at_trx_commit = 0 10.innodb_log_file_size = 1024m 11.innodb_max_dirty_pages_pct = 90 1.sysbench参数(读写):
1.sysbench --test=oltp --mysql-table-engine=innodb --oltp-table-size=100000000 --max-requests=1000000 --num-threads=100  2.--mysql-host=192.168.110.121  --mysql-port=3306 --mysql-user=admin --mysql-password=123456 --mysql-db=test  3.--oltp-table-name=sbtest --mysql-socket=/tmp/mysql.sock run sbtest表1亿条记录,文件大小24g。
下面是16k性能图:
1.innodb_page_size = 16k
下面是8k性能图:
1.innodb_page_size = 8k
1.结论:默认页16k,对cpu压力较小,平均在20% 2.8k页,cpu压力为30%~40%,但select吞吐量要高于16k
--------------------------------------------------------------------------------
2.sysbench参数(只读):
1.sysbench --test=oltp --mysql-table-engine=innodb --oltp-table-size=10000000 --max-requests=0 --num-threads=100  2.--oltp-read-only=on --mysql-host=192.168.110.121  --mysql-port=3306 --mysql-user=admin --mysql-password=123456 --mysql-db=test 3. --oltp-table-name=sbtest --mysql-socket=/tmp/mysql.sock run sbtest表1亿条记录,文件大小24g。
下面是16k和8k性能图:
其它类似信息

推荐信息