MySQL分区性能测试
By 成江东, on 八月 31st, 2010
一,测试服务器配置:
Cpu: 2*4核Intel(R) Xeon(R) E5405 @ 2.00GHz
内存:4G
存储:36块1T的7.2K的SATA组成raid0。使用其中的1T
Mysql版本:5.1.45-community-log MySQL Community Server (GPL)
二,建测试表:
Myisam不分区不分表,单表10亿数据量:
[code type=sql]
create table biguser
(
ID bigint not null auto_increment comment ‘自增ID’,
Username varchar(30) not null comment ‘用户名’,
sex tinyint not null comment ‘性别’,
birthday datetime not null comment ‘生日’,
email varchar(50) not null comment ‘邮箱’,
tel int not null comment ‘手机’,
intro varchar(255) not null comment ‘个人简介’,
primary key (ID)
)
type = MYISAM
default charset=utf8;
[/code]
Myisam不分区,分10个表,单表1亿数据量:
[code type=sql]
create table user01
(
ID bigint not null auto_increment comment ‘自增ID’,
Username varchar(30) not null comment ‘用户名’,
sex tinyint not null comment ‘性别’,
birthday datetime not null comment ‘生日’,
email varchar(50) not null comment ‘邮箱’,
tel int not null comment ‘手机’,
intro varchar(255) not null comment ‘个人简介’,
primary key (ID)
)
type = MYISAM
default charset=utf8;
[/code]
*一共10个表,user01,user02,…,user10
Myisam用id进行hash分区,分10个区,每个分区1亿数据:
[code type=sql]
create table puser
(
ID bigint not null auto_increment comment ‘自增ID’,
Username varchar(30) not null comment ‘用户名’,
sex tinyint not null comment ‘性别’,
birthday datetime not null comment ‘生日’,
email varchar(50) not null comment ‘邮箱’,
tel int not null comment ‘手机’,
intro varchar(255) not null comment ‘个人简介’,
primary key (ID)
)
type = MYISAM
default charset=utf8
partition by hash(ID)
partitions 10;
[/code]
Innodb用id进行hash分区,分10个区,每个分区1亿数据:
[code type=sql]
create table iuser
(
ID bigint not null auto_increment comment ‘自增ID’,
Username varchar(30) not null comment ‘用户名’,
sex tinyint not null comment ‘性别’,
birthday datetime not null comment ‘生日’,
email varchar(50) not null comment ‘邮箱’,
tel int not null comment ‘手机’,
intro varchar(255) not null comment ‘个人简介’,
primary key (ID)
)
type = Innodb
default charset=utf8
partition by hash(ID)
partitions 10;
[/code]
Innodb不分区不分表,单表10亿数据量:
[code type=sql]
create table ibiguser
(
ID bigint not null auto_increment comment ‘自增ID’,
Username varchar(30) not null comment ‘用户名’,
sex tinyint not null comment ‘性别’,
birthday datetime not null comment ‘生日’,
email varchar(50) not null comment ‘邮箱’,
tel int not null comment ‘手机’,
intro varchar(255) not null comment ‘个人简介’,
primary key (ID)
)
type = Innodb
default charset=utf8;
[/code]
三,数据生成
利用power design生成100万不重复的数据的基础表,然后将此表数据用mysqlslap工具重复插入到目标表,可以快速生成海量数量表。最终数据文件大小都在170G左右(分表情况单表17G数据文件)
插入100万记录到目标表的性能如下
单位(秒):
Myisam不分区 | Myisam分区 | Innodb不分区 | Innodb分区 | |
10.514 | 9.114 | 16.258 | 16.893 |
可见非并发的大量数据插入myisam分区性能最佳,myisam不分区次之,innodb分区较差。
四,压力测试
利用mysql5.1自带的压力测试工具mysqlslap对以上四种情况进行了压力测试,测试结果如下(单位:秒):
myisam未分区 | myisam分区 | Myisam分表 | Innodb未分区 | innodb分区 | |
100连续随机查询 | 4.55 | 4.11 | 5.389 | 4.445 | 5.893 |
并发50随机查询 | 0.052 | 0.049 | 0.075 | 0.07 | 0.038 |
并发100随机查询 | 0.071 | 0.078 | 0.11 | 0.088 | 0.055 |
并发250随机查询 | 0.137 | 0.153 | 0.239 | 0.175 | 0.124 |
并发500随机查询 | 0.266 | 0.273 | 0.447 | 0.283 | 0.24 |
并发1000随机查询 | 0.5 | 0.533 | 0.849 | 0.485 | 0.46 |
并发50随机插入 | 0.037 | 0.03 | 0.04 | 0.042 | 0.025 |
并发100随机插入 | 0.071 | 0.06 | 0.057 | 0.06 | 0.049 |
并发250随机插入 | 0.179 | 0.159 | 0.144 | 0.135 | 0.132 |
并发500随机插入 | 0.384 | 0.327 | 0.332 | 0.248 | 0.25 |
并发1000随机插入 | 0.82 | 0.73 | 0.737 | 0.542 | 0.526 |
并发50随机删除 | 1.204 | 1.536 | 0.196 | 0.041 | 0.039 |
并发100随机删除 | 2.333 | 2.945 | 0.362 | 0.062 | 0.063 |
并发250随机删除 | 5.568 | 5.718 | 0.831 | 0.14 | 0.173 |
并发500随机删除 | 9.663 | 9.705 | 1.42 | 0.275 | 0.308 |
并发1000随机删除 | 19.877 | 17.254 | 2.655 | 0.589 | 0.634 |
并发50随机更新 | 1.008 | 0.887 | 0.298 | 0.044 | 0.046 |
并发100随机更新 | 1.789 | 1.688 | 0.533 | 0.064 | 0.062 |
并发250随机更新 | 4.291 | 3.986 | 1.029 | 0.134 | 0.145 |
并发500随机更新 | 8.357 | 7.872 | 1.783 | 0.306 | 0.288 |
并发1000随机更新 | 15.963 | 15.126 | 3.33 | 0.575 | 0.563 |
*运行了一个100条语句的批查询,看非并发情况下的查询效率,查询语句见附一。
*利用存储过程进行一个hash处理,去对不同的表进行数据操作,见附二。
五,结论:
一,在高并发情况下,innodb的分区表的增,删,改,查的性能都优于myisam引擘,特别是在高并发删除和更新的场合下,两者相差可以达到20-30倍。
二,myisam的分区表(10个分区)和未分区表的性能相差不大,略优于未分区表。
三,myisam分区表(10个分区)的插入性能与分表(10个表)差不多,但查询性能要好30%左右。但删除与更新的性能分表要远远好于分区。
四,innodb分区表和未分区表查询和插入在低并发下,相差40%。但在并发性不断增加的情况下,性能相差不大。删除和更新性能则一直相近。
附一:
[code type=sql]
select sql_no_cache * from biguser where id= 14988469 ;
select sql_no_cache * from biguser where id= 57611709 ;
select sql_no_cache * from biguser where id= 88737417 ;
select sql_no_cache * from biguser where id= 5487431 ;
select sql_no_cache * from biguser where id= 75912772 ;
select sql_no_cache * from biguser where id= 39680341 ;
select sql_no_cache * from biguser where id= 33444232 ;
select sql_no_cache * from biguser where id= 53937959 ;
select sql_no_cache * from biguser where id= 29031225 ;
select sql_no_cache * from biguser where id= 1256108 ;
select sql_no_cache * from biguser where id= 25314369 ;
select sql_no_cache * from biguser where id= 24296361 ;
select sql_no_cache * from biguser where id= 65966713 ;
select sql_no_cache * from biguser where id= 14395018 ;
select sql_no_cache * from biguser where id= 69197350 ;
select sql_no_cache * from biguser where id= 90962562 ;
select sql_no_cache * from biguser where id= 67908690 ;
select sql_no_cache * from biguser where id= 34352967 ;
select sql_no_cache * from biguser where id= 76458078 ;
select sql_no_cache * from biguser where id= 9986401 ;
select sql_no_cache * from biguser where id= 92969693 ;
select sql_no_cache * from biguser where id= 21688034 ;
select sql_no_cache * from biguser where id= 23534033 ;
select sql_no_cache * from biguser where id= 49682571 ;
select sql_no_cache * from biguser where id= 70230582 ;
select sql_no_cache * from biguser where id= 23174504 ;
select sql_no_cache * from biguser where id= 54671332 ;
select sql_no_cache * from biguser where id= 60255403 ;
select sql_no_cache * from biguser where id= 33064209 ;
select sql_no_cache * from biguser where id= 30657185 ;
select sql_no_cache * from biguser where id= 98478707 ;
select sql_no_cache * from biguser where id= 27247625 ;
select sql_no_cache * from biguser where id= 20287058 ;
select sql_no_cache * from biguser where id= 67371577 ;
select sql_no_cache * from biguser where id= 18519687 ;
select sql_no_cache * from biguser where id= 55236080 ;
select sql_no_cache * from biguser where id= 21413273 ;
select sql_no_cache * from biguser where id= 2928926 ;
select sql_no_cache * from biguser where id= 82738229 ;
select sql_no_cache * from biguser where id= 47525876 ;
select sql_no_cache * from biguser where id= 19732304 ;
select sql_no_cache * from biguser where id= 63153463 ;
select sql_no_cache * from biguser where id= 1685048 ;
select sql_no_cache * from biguser where id= 4675229 ;
select sql_no_cache * from biguser where id= 14525956 ;
select sql_no_cache * from biguser where id= 86972953 ;
select sql_no_cache * from biguser where id= 21576455 ;
select sql_no_cache * from biguser where id= 5341705 ;
select sql_no_cache * from biguser where id= 66182739 ;
select sql_no_cache * from biguser where id= 54662774 ;
select sql_no_cache * from biguser where id= 59012070 ;
select sql_no_cache * from biguser where id= 52293127 ;
select sql_no_cache * from biguser where id= 29983640 ;
select sql_no_cache * from biguser where id= 21078779 ;
select sql_no_cache * from biguser where id= 14937593 ;
select sql_no_cache * from biguser where id= 17458594 ;
select sql_no_cache * from biguser where id= 7928885 ;
select sql_no_cache * from biguser where id= 73174679 ;
select sql_no_cache * from biguser where id= 21741457 ;
select sql_no_cache * from biguser where id= 86001336 ;
select sql_no_cache * from biguser where id= 52555158 ;
select sql_no_cache * from biguser where id= 23325556 ;
select sql_no_cache * from biguser where id= 63580254 ;
select sql_no_cache * from biguser where id= 83699681 ;
select sql_no_cache * from biguser where id= 10742003 ;
select sql_no_cache * from biguser where id= 81051582 ;
select sql_no_cache * from biguser where id= 45963004 ;
select sql_no_cache * from biguser where id= 95947261 ;
select sql_no_cache * from biguser where id= 19606015 ;
select sql_no_cache * from biguser where id= 24078829 ;
select sql_no_cache * from biguser where id= 676655 ;
select sql_no_cache * from biguser where id= 30713754 ;
select sql_no_cache * from biguser where id= 29905848 ;
select sql_no_cache * from biguser where id= 99763851 ;
select sql_no_cache * from biguser where id= 1495837 ;
select sql_no_cache * from biguser where id= 71316631 ;
select sql_no_cache * from biguser where id= 88798686 ;
select sql_no_cache * from biguser where id= 94214594 ;
select sql_no_cache * from biguser where id= 54310537 ;
select sql_no_cache * from biguser where id= 81828596 ;
select sql_no_cache * from biguser where id= 89927714 ;
select sql_no_cache * from biguser where id= 72684768 ;
select sql_no_cache * from biguser where id= 50764835 ;
select sql_no_cache * from biguser where id= 50720945 ;
select sql_no_cache * from biguser where id= 63690819 ;
select sql_no_cache * from biguser where id= 14890423 ;
select sql_no_cache * from biguser where id= 94762181 ;
select sql_no_cache * from biguser where id= 45487268 ;
select sql_no_cache * from biguser where id= 50795204 ;
select sql_no_cache * from biguser where id= 43415976 ;
select sql_no_cache * from biguser where id= 44953453 ;
select sql_no_cache * from biguser where id= 83626479 ;
select sql_no_cache * from biguser where id= 42730160 ;
select sql_no_cache * from biguser where id= 15229715 ;
select sql_no_cache * from biguser where id= 22058075 ;
select sql_no_cache * from biguser where id= 35277893 ;
select sql_no_cache * from biguser where id= 90205735 ;
select sql_no_cache * from biguser where id= 12501310 ;
select sql_no_cache * from biguser where id= 24653162 ;
select sql_no_cache * from biguser where id= 34248456 ;
[/code]
附二:
[code type=sql]
use nopart ;
drop procedure p_hash_select;
delimiter //
create procedure p_hash_select(vid bigint)
begin
set @i=mod(vid,10);
if @i=1 then
select * from user01 where;
end if;
if @i=2 then
select * from user02 where;
end if;
if @i=3 then
select * from user03 where;
end if;
if @i=4 then
select * from user04 where;
end if;
if @i=5 then
select * from user05 where;
end if;
if @i=6 then
select * from user06 where;
end if;
if @i=7 then
select * from user07 where;
end if;
if @i=8 then
select * from user08 where;
end if;
if @i=9 then
select * from user09 where;
end if;
if @i=0 then
select * from user10 where;
end if;
end//
[/code]
发表评论