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秒多。


注:此文版权归我同事。

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
### 回答1: 要使用Loadrunner测试Mysql数据库性能,需要遵循以下步骤: 1. 安装Loadrunner软件,并在Loadrunner中打开Vugen(Virtual User Generator)。 2. 在Vugen中创建一个新的脚本,并选择协议类型为ODBC。 3. 配置ODBC数据源,以便与Mysql数据库建立连接。 4. 在脚本中添加数据库操作,比如插入、更新、查询等。 5. 设置负载测试参数,如虚拟用户数、持续时间、并发请求数等。 6. 运行负载测试,收集性能数据。 7. 分析性能数据,发现潜在的性能瓶颈,并进行优化。 需要注意的是,在进行负载测试前,要确保Mysql数据库已经正确地配置和优化,以避免测试结果受到数据库本身的限制。另外,负载测试要在生产环境之外进行,以避免对实际业务造成影响。 ### 回答2: 运用Loadrunner对MySQL数据库进行性能测试是一种常见的方法。Loadrunner是一款功能强大的性能测试工具,可以模拟多个用户同时对MySQL数据库进行读写操作,以评估数据库在高负载情况下的性能表现。 首先,需要创建一个测试场景,包括模拟用户的行为和操作,例如数据库查询、插入、更新和删除等操作。然后,设置虚拟用户数量和并发数,以模拟实际应用场景下的负载。 其次,配置数据库连接参数,包括数据库服务器地址、端口号、用户名和密码等。Loadrunner可以使用自带的数据库协议模拟真实的数据库请求,通过执行SQL语句向数据库发送请求。 接下来,使用Loadrunner的脚本编辑器编写脚本,包括数据库连接、查询、更新等操作。可以通过录制脚本的方式,将用户的操作转化为脚本,或者手动编写脚本以模拟特定的数据库操作。 一旦脚本编写完成,可以开始进行性能测试。Loadrunner可以按照预先设定的虚拟用户数量和并发数,同时运行多个用户脚本,模拟多个用户对数据库进行操作。 在测试运行期间,Loadrunner会收集各种性能指标,例如响应时间、吞吐量、并发数等。通过分析这些指标,可以评估数据库性能,并找出潜在的性能瓶颈。 最后,可以根据测试结果进行优化和调整。通过不断重复测试、分析和优化的循环,可以提高MySQL数据库性能,提供更好的用户体验。[300字] ### 回答3: 使用LoadRunner测试MySQL数据库性能可以通过以下步骤进行: 1. 安装LoadRunner:首先,需要下载并安装LoadRunner软件,确保版本兼容并按照指示进行安装。 2. 创建脚本:在LoadRunner的Vuser脚本编辑器中,创建一个新的脚本来模拟对MySQL数据库的访问。脚本包括必要的代码和配置,例如数据库连接,查询语句等。 3. 参数化:通过参数化数据,可以模拟多个用户同时访问数据库。可以使用LoadRunner内置的参数化功能来实现。将脚本中的固定数据替换为参数,例如使用用户名、密码和查询语句等。 4. 创建虚拟用户:使用LoadRunner的“Virtual User Generator”创建虚拟用户,配置虚拟用户数量和行为。为每个虚拟用户分配不同的参数值,以模拟多个用户的并发访问。 5. 运行负载测试:使用LoadRunner的控制台或命令行界面来运行负载测试。在测试期间,LoadRunner会模拟多个虚拟用户并发地访问MySQL数据库,并且记录关键性能指标,如响应时间、吞吐量等。 6. 分析结果:在测试结束后,可以使用LoadRunner的分析工具来查看测试结果。可以生成图表和报告,以便更好地理解数据库性能,并识别潜在的性能瓶颈和问题。 需要注意的是,在进行MySQL数据库性能测试时,应确保测试环境的合理性和一致性。数据库服务器的配置、网络连接和负载情况等因素都可以对测试结果产生影响,因此应尽可能模拟真实的生产环境进行性能测试

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值