使用sysbench进行MySQL压力测试

Posted wq_庆

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用sysbench进行MySQL压力测试相关的知识,希望对你有一定的参考价值。

一、介绍

  sysbench是一款开源的多线程性能测试工具,可以执行CPU/内存/线程/IO/数据库等方面的性能测试。本身支持mysql数据库的压测。

   是业内最常用的数据库多线程基准测试工具,官方 1.0 版本发布以后,能够基于 lua 脚本进行定制测试,十分方便。

二、安装

  yum安装:yum install sysbench

三、参数说明

       sysbench 安装完成后,可以查看 sysbench 安装的版本:  

  

  通过help查看参数:

  [root@iZbp1hvphr2ekyo7x52pibZ ~]# sysbench --help

  sysbench 使用语法如下:
       sysbench [options]... [testname] [command]
  其中:
  options 为参数选项
  testname 指定基准测试 oltp*.lua 脚本
  command 是要执行什么样的操作
  下面对这三部分分别进行说明
  1. command 命令
    sysbench 的 command 是控制命令,包含以下几个选项:
    prepare, prewarm, run, cleanup, help
    其中:
    prepare 表示测试前准备,主要创建表,生成初始测试数据
    prewarm 表示测试前进行预热
    run 表示执行测试,根据各种测试场景进行测试
    cleanup 表示测试完后清理测试数据
    help 获取帮助文档

  2. testname 测试选项
    sysbench 的 testname 是表示要测试的场景,目前 sysbench 自带的针对 mysql
    oltp 测试场景有如下几种:

  • oltp_delete.lua 删除测试
  • oltp_insert.lua 插入测试
  • oltp_point_select.lua 主键查询测试
  • oltp_read_only.lua 只读测试
  • oltp_read_write.lua 读写测试
  • oltp_update_index.lua 更新索引测试
  • oltp_update_non_index.lua 更新非索引测试
  • oltp_write_only.lua 只写测试
  • select_random_points.lua 随机多个查询(in 里面多个查询条件)
  • select_random_ranges.lua 随机范围查询(between … and …)

  3. options 选项
  sysbench 的 options 里面包含测试需要的各种参数,包括初始化、预热、运行以及不同测试场景中需要的参数,具体如下:
  1)  通用选项
    选项 描述 默认值

  • --threads=N 线程数 默认为1
  • --events=N 请求数限制,0 代表无限制 默认为0
  • --time=N 测试执行时长(单位:秒)限制 默认为10
  • --forced-shutdown=STRING 超过--time 后,强制中断测试(off 代表不启用,on代表启用)默认为off
  • --thread-stack-size=SIZE 每个线程的堆栈大小(k、M、G 单位都可)默认为64K
  • --report-interval=N 每 N 秒输出一份中间统计结果, 0 表示不输出中间统计结果 默认为0
  • --tx-rate=N 已经废弃,被--rate 取代 0
  • --max-requests=N 已经废弃,被--events 取代 0
  • --max-time=N 已经废弃,被--time 取代 0
  • --num-threads=N 已经废弃,被--threads 取代 1

  2)  伪随机数发生器
    选项 描述 默认值

  • --rand-type=STRING 随机数分布(uniform、gaussian、special、pareto)默认为special
  • --rand-spec-iter=N 用于数字生成的迭代次数 默认为12
  • --rand-spec-pct 被当作 special 值所占百分比 默认1
  • --rand-spec-res=N 多少比例的 special 值被使用 默认为75
  • --rand-seed=N 随机发生器种子,为 0 时,使用当前时间作为随机种子 默认为0
  • --rand-pareto-h=N 是用 pareto 分布时的 h 参数 默认为0.2

  3) 日志选项
    日志选项
    选项 描述 默认值

  • --verbosity=N 信息级别(5-debug、0-关键信息) 默认为3
  • --percentile=N 取百分比段位延迟进行统计计算(1-100) 默认为95
  • --histogram[=on|off] 在报告中打印延迟直方图 off

  4)  数据库选项
    通用数据库选项
    选项 描述 默认值
    --db-driver=STRING
    指定数据库驱动,默认安装支持:
      mysql - MySQL driver
      pgsql - PostgreSQL driver
    --db-ps-mode=STRING prepare 语句使用(auto、disable) 默认为auto
    --db-debug[=on|off] 是否打印数据库特有的调试信息 默认为off
  

  mysql 选项
  选项 描述 默认值

  • --mysql-host=[LIST,...] mysql 主机 localhost
  • --mysql-port=[LIST,...] mysql 端口 3306
  • --mysql-socket=[LIST,...] mysql 本地 socket 路径
  • --mysql-user=STRING mysql 测试用户 sbtest
  • --mysql-password=STRING mysql 测试用户密码
  • --mysql-db=STRING mysql 测试库名 sbtest
  • --mysql-ssl[=on|off] 如果客户端支持,是否使用 SSL 连接 Off
  • --mysql-ssl-cipher=STRING 使用 SSL 连接的特定密码
  • --mysql-compression[=on|off] 如果客户端支持,是否使用压缩 Off
  • --mysql-debug[=on|off] 追踪所有客户端的调用 Off
  • --mysql-ignore-errors=[LIST,...] 忽略错误列表(比如 1213,1020,1205,或者 all)
  • --mysql-dry-run[=on|off] 只运行,假装所有的客户端调用都执行成功,实际并没有执行它们 默认为off

  oltp 选项
  选项 描述 默认值

  • --test=STRING 指定 oltp 测试的 lua 脚本:
  • --table-size 单表记录数,取代--oltp-table-size 10000
  • --range-size 范围查询时的范围 100
  • --tables 表数量,取代--oltp-tables-count 1
  • --point-selects 主键查询测试时,每事务查询语句数 10
  • --simple-ranges 简单范围查询,每事务查询语句数 1
  • --sum-ranges 每个事务中 sum()查询语句数 1
  • --order-ranges 每个事务中 order by 查询语句数 1
  • --distinct-ranges 每个事务中 distinct 查询语句数 1
  • --index-updates 每个事务中更新索引语句数 1
  • --non-index-updates 每个事务中更新非索引字段语句数 1
  • --delete-inserts 每个事务中 delete/insert 语句数 1
  • --range-selects 是否开启所有的范围查询 true
  • --auto-inc 是否使用自增列 true
  • --skip-trx 不显式开启事务,所有查询使用autocommit 模式 false
  • --secondary 是否使用二级索引代替主键索引 false
  • --create-secondary 除了主键索引外,是否创建二级索引 True
  • --mysql-storage-engine mysql 存储引擎 innodb

四、数据准备

  需要先创建数据库,testdb

sysbench --test=/usr/share/sysbench/oltp_insert.lua \\
--mysql-host=127.0.0.1\\
--mysql-port=3306 \\
--mysql-user=root \\
--mysql-password=\'12345678\' \\
--mysql-db=testdb \\
--db-driver=mysql \\
--tables=10 \\
--table-size=500000 \\
--report-interval=10 \\
--threads=128 \\
prepare

 

  创建十个表,一个表500000数据

五、测试

  示例:测试主键查询,5个线程,压测200s,10s打一次报告

sysbench --test=/usr/share/sysbench/oltp_point_select.lua \\
--mysql-host=127.0.0.1 \\
--mysql-port=3306 \\
--mysql-user=root\\
--mysql-password=\'12345678\' \\
--mysql-db=testdb \\
--db-driver=mysql \\
--table-size=500000\\
--report-interval=10 \\
--threads=5\\
--time=200\\
run

 

六、测试报告  

  测试结果:

  

 

   

  统计报告参数说明:

  SQL statistics:

  queries performed:

  read:  //总 select 数

  write:  //总 dml 数

  other: //begin,commit,lock tables 以及 mutex 数

 

  total: //总查询量

  transactions: //TPS

  queries: //QPS

  ignored errors:  //忽略错误数

  reconnects: 0 (0.00 per sec.)

 

  General statistics:

  total time:  --time 指定的压测时间

  total number of events: //总的请求次数

 

  Latency (ms):

  min:  //最小响应时间

  avg:  //平均响应时间

  max:  //最大响应时间

  99th percentile:  //99%的语句相应时间

  sum:  //总查询时间

七、清空测试数据和表

sysbench --test=/usr/share/sysbench/oltp_insert.lua \\
--mysql-host=127.0.0.1\\
--mysql-port=3306 \\
--mysql-user=root \\
--mysql-password=\'12345678\' \\
--mysql-db=testdb \\
--db-driver=mysql \\
--tables=10 \\
--table-size=500000 \\
--report-interval=10 \\
--threads=128 \\
cleanup

 

以上是关于使用sysbench进行MySQL压力测试的主要内容,如果未能解决你的问题,请参考以下文章

使用sysbench进行MySQL压力测试

MySQL压测使用sysbench对MySQL进行压力测试

Sysbench压力测试工具简介和使用

使用sysbench对mysql压力测试

sysbench压力测试总结

sysbench压力测试工具简介