高性能MySQL-2、MySQL基准测试

第二章、MySQL基准测试(压力测试)

一、为什么需要基准测试

基准测试可以观察系统在不同压力下的行为,评估系统的容量,掌握哪些是重要的变化,或者观察系统如何处理不同的数据。
验证基于系统的假设,确认假设符合实际情况

  • 重现异常;
  • 测试系统当前的运行情况,利用历史基准测试结果来分析优化的效果。
  • 模拟比当前系统更高的负载,找出系统压力增加而可能遇到的扩展性瓶颈。
  • 规划未来的业务增长,评估资源,降低系统升级或重大变更的风险。
  • 测试系统在不同环境下的表现和能力,如不同配置的服务器和不同的数据分布

二、基准测试的策略

1、两种主要的策略

  • 针对整个系统的整体测试(集成式full-stack)
  • 单独测试MySQL(单组件式 single-component)

2、测试何种指标:

  • 吞吐量:指单位时间内的事务处理数,常用的测试单位是每秒事务数(Tps),或者每分钟事务数(TPM)
  • 响应时间或者延迟:用于测试任务所需的整体时间,根据具体的应用。测试的时间单位可能是微秒、毫秒,秒或者分钟,通常使用百分比响应时间( percentile response time)来替代最大响应时间,如95%的响应时间都是5毫秒。
  • 并发性:需要关注的是正在工作中的并发操作,或者是同时工作中的线程数或者连接数,在测试间记录 MYSQL数据库的 Threads running状态值
  • 可扩展性:给系统增加一倍的工作,在理想情况下就能获得两倍的效果(即吞吐量增加一倍),对于容量规范非常有用,可以提供其他测试无法提供的信息,来帮助发现应用的瓶颈。

三、基准测试方法

需要避免的一登常见错误:

  • 使用真实数据的子集而不是全集
  • 使用错误的数据分布,真实数据有很多热点,随机生成的数据通常无法模拟真实数据分布
  • 使用不真实的分布参数,例如假设所有用户的个人信息都被平均的读取
  • 在多用户场景中,只做单用户测试
  • 在单服务器上测试分布式应用
  • 与真实用户行为不匹配,如WEB页面的“思考时间,真实用户不会不停顿的一个接一个点击相关操作,
  • 反复执行同一个直询,会对缓存的使用情况产生影响
  • 没有检查错误,对快和慢得到合理解释
  • 忽略了系统预热( warm up)的过程
  • 使用默认的服务器配置
  • 测试时间太题

1.应该建立将参数和结果文档化的规范,每一轮测试都必须进行详细记录
2.基准测试应该运行足够长的时间,需要在稳定状态下测试并观察
3.在执行基准测试时,需要尽可能多地收集被测试系统的信息
4.自动化基准测试可以防止测试人员偶尔遗漏某些步骤,或者误操作,另外也有助于归档整个测试过程,可以选择shell、php、perl等,要尽可能使所有测试过程都自动化,包括装载数据、系统预热,执行测试,记录结果等

四、基准测试工具

集成式测试工具

  • ab,测试HTTP服务器每秒最多可以处理多少请求
  • http_load,和ab似,但更加灵活
  • jMeter,可以加载其他应用并测试其性能

单组件测试工具

  • mysqlslap,可以模拟服务器的负载,并输出计时信息
  • MysQL Benchmark Suite( sql-bench).单线程的,主要用于测试服务器执行查询的速度
  • Super Smack,提供压力测试和负载生成,是一个复杂而强大的工具,可以模拟多用户访问,可以加载测试数据到数据库,并支持使用随机数据填充测试表
  • Database Test suite,类似某些工业标准测试的测试工具集
  • Percoma’s TPCC-MySQWL Tool
  • sysbench,多线程系统压测工具,可以根据影响数据库服务器性能的各种因素来评估系统的性能
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值