|
从MySQL5.6开始,一个新参数innodb_page_size可以设置Innodb数据页为8K,4K,默认为16K。这个参数在一开始初始化时就要加入my.cnf里,如果已经创建了表,再修改,启动MySQL会报错。 参考手册: <IMG style="PADDING-BOTTOM: 0px; MARGIN: 0px; PADDING-LEFT: 0px; PADDING-RIGHT: 0px; VERTICAL-ALIGN: top; PADDING-TOP: 0px" title="MySQL5.6 Innodb数据页 16K vs 8K性能对比测试" border=0 alt="" src="http://img1.****.com/attachment/201209/153531132.jpg" width=650 real_src="http://img1.****.com/attachment/201209/153531132.jpg"> 下面我针对16K和8K做了一个压力测试。 硬件:R710,72G内存,6块300G、15000转做的RAID10,XFS分区。 my.cnf参数:
$ i$ i" W) t5 F R8 Kinnodb_buffer_pool_size = 48G innodb_buffer_pool_instances = 8 innodb_flush_method = O_DIRECT innodb_file_per_table = 1 innodb_read_io_threads = 16 innodb_write_io_threads = 16 innodb_io_capacity = 2000 innodb_log_files_in_group = 3 innodb_flush_log_at_trx_commit = 0 innodb_log_file_size = 1024M - innodb_max_dirty_pages_pct = 90 " t" G6 n8 J. G4 k4 q5 u6 O! M4 D
1.Sysbench参数(读写):
8 {' O: M' S) L/ N; S$ A3 `sysbench --test=oltp --mysql-table-engine=innodb --oltp-table-size=100000000 --max-requests=1000000 --num-threads=100 --mysql-host=192.168.110.121 --mysql-port=3306 --mysql-user=admin --mysql-password=123456 --mysql-db=test - --oltp-table-name=sbtest --mysql-socket=/tmp/mysql.sock run
4 F; M. U Z* m% r3 I; r8 K
sbtest表1亿条记录,文件大小24G。 下面是16K性能图: - innodb_page_size = 16k
/ A5 w+ f! m4 j7 g. X2 X4 s( l! e1 u& `5 k
<IMG style="PADDING-BOTTOM: 0px; MARGIN: 0px; PADDING-LEFT: 0px; PADDING-RIGHT: 0px; VERTICAL-ALIGN: top; PADDING-TOP: 0px" title="MySQL5.6 Innodb数据页 16K vs 8K性能对比测试" border=0 alt="" src="http://img1.****.com/attachment/201209/153901524.jpg" width=650 real_src="http://img1.****.com/attachment/201209/153901524.jpg"> <IMG style="PADDING-BOTTOM: 0px; MARGIN: 0px; PADDING-LEFT: 0px; PADDING-RIGHT: 0px; VERTICAL-ALIGN: top; PADDING-TOP: 0px" title="MySQL5.6 Innodb数据页 16K vs 8K性能对比测试" border=0 alt="" src="http://img1.****.com/attachment/201209/153939213.jpg" width=650 real_src="http://img1.****.com/attachment/201209/153939213.jpg"> 下面是8K性能图: - innodb_page_size = 8k
/ X! G K5 I, n) Q% \
<IMG style="PADDING-BOTTOM: 0px; MARGIN: 0px; PADDING-LEFT: 0px; PADDING-RIGHT: 0px; VERTICAL-ALIGN: top; PADDING-TOP: 0px" title="MySQL5.6 Innodb数据页 16K vs 8K性能对比测试" border=0 alt="" src="http://img1.****.com/attachment/201209/154017131.jpg" width=650 real_src="http://img1.****.com/attachment/201209/154017131.jpg"> <IMG style="PADDING-BOTTOM: 0px; MARGIN: 0px; PADDING-LEFT: 0px; PADDING-RIGHT: 0px; VERTICAL-ALIGN: top; PADDING-TOP: 0px" title="MySQL5.6 Innodb数据页 16K vs 8K性能对比测试" border=0 alt="" src="http://img1.****.com/attachment/201209/154035607.jpg" width=650 real_src="http://img1.****.com/attachment/201209/154035607.jpg"> : E/ `& u" B3 B' f# j
结论:默认页16K,对CPU压力较小,平均在20%
9 u0 |4 w' O0 V8 h0 x
4 m0 g! F5 j7 n$ |7 l8 X- 8K页,CPU压力为30%~40%,但select吞吐量要高于16K 7 d* V7 n/ p" ]: j3 b$ P/ `8 ]7 \
3 S7 p) L) }. ]) V) O; ~7 N
2.Sysbench参数(只读):
" j5 w+ r3 z' Bsysbench --test=oltp --mysql-table-engine=innodb --oltp-table-size=10000000 --max-requests=0 --num-threads=100 --oltp-read-only=on --mysql-host=192.168.110.121 --mysql-port=3306 --mysql-user=admin --mysql-password=123456 --mysql-db=test - --oltp-table-name=sbtest --mysql-socket=/tmp/mysql.sock run ( ]& `" ]( g/ T% p7 a; h9 t/ F
sbtest表1亿条记录,文件大小24G。 下面是16K和8K性能图: <IMG style="PADDING-BOTTOM: 0px; MARGIN: 0px; PADDING-LEFT: 0px; PADDING-RIGHT: 0px; VERTICAL-ALIGN: top; PADDING-TOP: 0px" title="MySQL5.6 Innodb数据页 16K vs 8K性能对比测试" border=0 alt="" src="http://img1.****.com/attachment/201209/154417492.jpg" width=650 real_src="http://img1.****.com/attachment/201209/154417492.jpg"> <IMG style="PADDING-BOTTOM: 0px; MARGIN: 0px; PADDING-LEFT: 0px; PADDING-RIGHT: 0px; VERTICAL-ALIGN: top; PADDING-TOP: 0px" title="MySQL5.6 Innodb数据页 16K vs 8K性能对比测试" border=0 alt="" src="http://img1.****.com/attachment/201209/154434798.jpg" width=650 real_src="http://img1.****.com/attachment/201209/154434798.jpg"> ! `4 W+ l" h6 h, @2 [3 m
结论:左边是16K,右边为8K,从图中所看,差别不是明显。 - 所以,针对读写很频繁,16K目前是性能比较好的。 4 s6 R# x; N3 d6 @+ M X
|