2、Mysql基准测试

准测试是针对系统设计的一种压力测试。通常的目标是为了掌握系统的行为。


为什么需要基准测试

基准测试是唯一方便有效的,可以学习系统在给定的工作负载下会发生什么的方法。基准测试可以观察系统在不同压力下的行为,评估系统的容量,掌握哪些是重要的变化,或者观察系统如何处理不同的数据。
基准测试可以在系统实际负载之外创造一些虚构的场景进行测试:

  • 验证基于系统的一些假设,确认这些假设是否符合实际情况
  • 重现系统中的某些异常行为,以解决这些异常
  • 测试系统当前的运行情况
  • 模拟比当前系统更高的负载,以找出系统随着压力增加而可能遇到的扩展性瓶颈
  • 规划未来业务增长
  • 测试应用适应可变环境的能力
  • 测试不同的硬件、软件和操作系统配置
  • 证明新采购的设备是否配置正确

基准测试的一个主要问题在于其不是真实的压力测试,基准测试施加给系统的压力相对真实压力来说比较简单。真实压力是不可预期而且变化多端的,有时候情况会过于复杂而难以解释。

基准测试的策略

基准测试有两种主要的策略:一是针对整个系统的整体测试,另外是单独测试Mysql。这两种策略也被称为集成式以及单组件式基准测试。
进行集成式测试的原因主要是:

  • 测试整个应用系统包括Web服务器,代码,网络和数据库是非常有用的,因为用户关注的是整体的应用而不是数据库
  • Mysql并不总是应用的瓶颈
  • 只有对应用做整体测试,才能发现各个部分之间的缓存带来的影响
  • 整体应用的集成式测试更能揭示应用的真实表现,而单独组件的测试很难做到这一点

另外整体基准测试很难建立,如果测试的设计有问题,那么结果就无法反映真实的情况。不过在项目初期可以选择只关注Mysql的性能做单独测试。

测试指标

  • 吞吐量:单位时间内的事务处理数
  • 响应时间或者延迟:用于测试任务所需的整体时间
  • 并发性
  • 可扩展性

基准测试方法

如何避免一些常见的错误:

  • 使用真实数据的子集而不是全集
  • 使用错误的数据分布
  • 使用不真实的分布参数
  • 在多用户场景中只做单用户测试
  • 在单服务器上测试分布式应用
  • 与真实用户行为不匹配
  • 反复执行同一个查询
  • 没有检查错误
  • 忽略了系统预热
  • 使用默认的服务器配置
  • 测试时间太短

设计和规划基准测试

规划基准测试的第一步就是提出问题并明确目标,然后决定是采用标准的基准测试还是设计专用的测试。

基准测试应该运行多长时间

基准测试应该运行足够长的时间,这一点很重要。如果需要测试系统在稳定状态时的性能,那么当然需要再稳定状态下测试并观察。而如果系统有大量的数据和内存,要达到稳定状态可能需要非常长的时间。
有时候无法确定测试需要运行多长时间,可以先一直运行持续观察直到确认系统已经稳定。

获取系统性能和状态

在执行基准测试时,需要尽可能多地收集被测试系统的信息。包括系统状态和性能指标,如CPU使用率,磁盘IO等等。

获得准确的测试结果

运行基准测试并分析结果

基准测试工具

集成式测试工具

ab

ab是Apache Http服务器基准测试工具。他可以测试HTTP服务器每秒最多可以处理多少请求。如果测试的是Web应用服务,这个结果可以转换成整个应用每秒可以满足多少请求。。

http_load

这个工具概念上和ab类似,也被设计为对Web服务器进行测试,但比ab更加灵活。

JMeter

JMeter是一个java应用程序,可以加载其他应用并测试其性能。虽然是设计用来测试Web应用的,但是也可以用于测试其他FTP服务器,或者通过JDBC进行数据库查询测试。

单组件式测试工具

mysqlslap

Mysql Benchmark Suite

Super Smack

Database Test Suite

Percona’s TPCC-Mysql Tool

sysbench

你可能感兴趣的:(Mysql高性能学习,mysql,数据库,sql,java,后端)