从MySQL5.6开始,一个新参数innodb_page_size可以设置Innodb数据页为8K,4K,默认为16K。这个参数在一开始初始化时就要加入my.cnf里,如果已经创建了表,再修改,启动MySQL会报错。参考手册:650) this.width=650;" border=0>下面我针对16K和8K做了一个压力测试。硬件:R710,72G内存,6块300G、15000转做的RAID10,XFS分区。my.cnf参数:
- innodb_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
1.Sysbench参数(读写):
- 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
sbtest表1亿条记录,文件大小24G。下面是16K性能图:
- innodb_page_size = 16k
650) this.width=650;" border=0>650) this.width=650;" border=0>下面是8K性能图:
- innodb_page_size = 8k
650) this.width=650;" border=0>650) this.width=650;" border=0>
- 结论:默认页16K,对CPU压力较小,平均在20%
- 8K页,CPU压力为30%~40%,但select吞吐量要高于16K
2.Sysbench参数(只读):
- sysbench --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
sbtest表1亿条记录,文件大小24G。下面是16K和8K性能图:650) this.width=650;" border=0>650) this.width=650;" border=0>结论:左边是16K,右边为8K,从图中所看,差别不是明显。 所以,针对读写很频繁,16K目前是性能比较好的。 phpMyAdmin老出现登陆超时解决方法Oracle 11gR2 RAC中修改数据库的SPFILE文件位置相关资讯 MySQL基础教程
- MySQL基础教程:关于varchar(N) (01月22日)
- MySQL SELECT同时UPDATE同一张表 (02/19/2013 07:20:18)
- Linux修改MySQL最大并发连接数 (02/15/2013 15:37:21)
| - 高性能MySQL(第3版) 中文PDF带目 (10/26/2014 10:03:50)
- 如何在MySQL中的获取IP地址的网段 (02/18/2013 12:23:33)
- C++和C#访问MySQL的简单代码示例 (12/21/2012 09:04:10)
|
本文评论 查看全部评论 (0)