MYSQL数据库性能测试报告

MYSQL数据库性能测试报告

 

测试环境:

       DELL 2.4G memory 512M

       RH9.0 MySql 3.23.54

测试使用的是mysql缺省参数,用mysql提供的APIC编写测试程序

测试程序共启动40个线程进行数据库操作,查找、插入、修改、删除各10个,每个线程独立与Sql Server连接。

数据库结构,单表,表结构如下:

       toheader         100byte 主键

       contactheader 100byte

       called       50byte

       cseq        100byte

       hashval      int

       timestamp       int  次键

对主次键分别建了索引。分别在5万、10万、50万用户环境做测试,结果如下:

 

查找100

插入100

修改100

删除100

5

100300ms

100300ms

100300ms

100300ms

10

500ms-1s

500ms-1s

500ms-1s

500ms-1s

50

3s-5s

3s-5s

3s-5s

3s-5s

从此数据看性能是很不错的,因为mysql能保证每个操作是原子的,所以不用考虑线程间的同步。

 

但有一个问题:即mysql的每个操作是原子的,所以做每个操作时,其它线程是阻塞的,在大数据量查询时,花的时间较长,会对其它线程有影响。我在保持其它线程工作不变的情况下,将每个查找线程改为做一次对所有记录的查询,在5万和10万记录时表现不错,分别为250ms450ms,但在50万记录时,这个数值达到了22秒。而且在50万用户时,通过条件查找部分数据也很慢,如查询结果为10万记录时用11秒。

怀疑是sql server的参数影响,按数据库说明修改了几个缓冲区的参数,但没有效果。

由于首次同步发生的频率很低,象250ms450ms这样的数据还是可以接受的,但22秒太离谱了。支持50万用户在线,需要考虑一个解决办法,现在有一个办法是建一个备份表,写备份表的请求放到一个队列里由一个单独线程处理,这样阻塞不会影响正常业务处理了。但这个线程的缓冲区要足够容纳30秒内发生的操作。

 

本来担心数据量大了mysql的缓冲区不够会出错或丢数据,但测试发现,一次查询最多读了50M数据,没有出现问题,经测算我们首次同步的数据不会超过10M

 

MySQL中启动了innoDB引擎后,可以实现真正的行级锁,selectupdate操作可以并发,这样在全表查询进行中间可以进行其它的selectupdate操作,但insertdelete不行。

性能也有很大提高,50万记录时100次操作300ms,全表查询11秒多。


注:此文版权归我同事。

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值