sysbench 0.5 性能测试工具使用手册

1. sysbench 介绍

  sysbench是一个模块化的、跨平台、多线程基准测试工具,主要用于评估测试各种不同系统参数 下的数据库负载情况。关于这个项目的详细介绍请看:http://sysbench.sourceforge.net。

  它主要包括以下几种方式的测试:

  cpu性能

  磁盘io性能

  调度程序性能

  内存分配及传输速度

  POSIX线程性能

  数据库性能(OLTP基准测试)

  目前sysbench主要支持MySQL,Pgsql和Oracle这3种数据库。

  2. 安装sysbench

  基于Debain的操作系统,可以直接安装:

  sudo apt-get install sysbench

  也可以下载源码,然后自己编译安装。

  项目主页:http://sysbench.sourceforge.net/

  下载地址:http://sourceforge.net/projects/sysbench

  文档地址:http://sysbench.sourceforge.net/docs

  3. 开始测试

  3.1 CPU性能测试

  根据官网的介绍可知:CPU测试使用64位整数,测试计算素数直到某个最大值所需要的时间。

  sysbench --test=cpu --cpu-max-prime=20000 run

  输出如下:


Maximum prime number checked in CPU test: 200000

Test execution summary:

total time:                          286.5703s

total number of events:              10000

total time taken by event execution: 285197.4463

per-request statistics:

min:                                109.67ms

avg:                              28519.74ms

max:                              36760.02ms

approx.  95 percentile:           31751.56ms

Threads fairness:

events (avg/stddev):           9.7656/0.81

execution time (avg/stddev):   278.5131/6.05

  我们只需要关心测试的总时间(total time)即可。

  CPU性能测试有一个需要注意的地方,上面的测试只使用了一个线程,如果在两个cpu processor不同的电脑上做比较,这是不公平的。公平的做法是指定合理的线程数,如下所示:

  sysbench --test=cpu --num-threads=`grep "processor" /proc/cpuinfo | wc -l` \

  --cpu-max-prime=200000 run
 补充知识:
  查看CPU核数的方法
  查看物理cpu个数
  grep "physical id" /proc/cpuinfo | sort -u | wc -l
  查看核心数量
  grep "core id" /proc/cpuinfo | sort -u | wc -l
  查看线程数量
  grep "processor" /proc/cpuinfo | sort -u | wc -l
  在sysbench的测试中,--num-threads取值为"线程数量"即可,再大的值没有什么意义,对测试结果也没有什么影响。
  3.2 线程(thread)测试
  测试线程调度器的性能。对于高负载情况下测试线程调度器的行为非常有用。
  sysbench --test=threads --num-threads=64 run
  下面是输出结果:

Number of threads: 64
Doing thread subsystem performance test
Thread yields per test: 1000 Locks used: 8
Threads started!
Done.
Test execution summary:
total time: 4.5845s
total number of events: 10000
total time taken by event execution: 291.9995
per-request statistics:
min: 0.76ms
avg: 29.20ms
max: 152.71ms
approx. 95 percentile: 71.11ms
Threads fairness:
events (avg/stddev): 156.2500/5.81
execution time (avg/stddev): 4.5625/0.02

  说实话,我也不怎么会分析这个测试结果,网上搜了半天也没有搜到,几乎所有的资料都是简单的罗列出测试结果, 也不告诉我们应该怎么分析,实在是太不照顾新手了。 我自己是通过(total time:)判断线程调度的性能的,下面是我在服务器上运行这个测试的输出:

Number of threads: 64
Doing thread subsystem performance test
Thread yields per test: 1000 Locks used: 8
Threads started!
Done.
Test execution summary:
total time: 2.4829s
total number of events: 10000
total time taken by event execution: 157.3468
per-request statistics:
min: 0.21ms
avg: 15.73ms
max: 166.69ms
approx. 95 percentile: 119.14ms
Threads fairness:
events (avg/stddev): 156.2500/22.25
execution time (avg/stddev): 2.4585/0.02

  可以看到total time 比在我自己电脑上少了一半,服务器的线程调度肯定比普通电脑快多了。

 3.3 互斥锁(mutex)
  测试互斥锁的性能,方式是模拟所有线程在同一时刻并发运行,并都短暂请求互斥锁。
sysbench --test=mutex --num-threads=16 --mutex-num=2048 \
--mutex-locks=1000000 --mutex-loops=5000 run
输出结果如下:

Number of threads: 16
Doing mutex performance test
Threads started!
Done.
Test execution summary:
total time: 3.6123s
total number of events: 16
total time taken by event execution: 57.6636
per-request statistics:
min: 3580.79ms
avg: 3603.98ms
max: 3610.94ms
approx. 95 percentile: 10000000.00ms
Threads fairness:
events (avg/stddev): 1.0000/0.00
execution time (avg/stddev): 3.6040/0.01

  为了不误导别人,我就不解释各参数的含义了,可以请参考这里。
  3.4 内存测试
  内存测试测试了内存的连续读写性能。
  sysbench --test=memory --memory-block-size=8K --memory-total-size=2G  --num-threads=16 run
  上面这条语句指定了整个测试过程中,传输2G的数据量,每个block的大小为8K(大写的K)。 测试结果如下所示,我们最关心的是吞吐量(8030.45MB/sec),和后面的磁盘io 测试结果比较可知,内存的连续读写比磁盘的连续读写快十几倍。

Number of threads: 16
Doing memory operations speed test
Memory block size: 8K
Memory transfer size: 2048M
Memory operations type: write
Memory scope type: global
Threads started!
Done.
Operations performed: 262144 (1027897.89 ops/sec)
2048.00 MB transferred (8030.45 MB/sec)
Test execution summary:
total time: 0.2550s
total number of events: 262144
total time taken by event execution: 3.1911
per-request statistics:
min: 0.00ms
avg: 0.01ms
max: 29.55ms
approx. 95 percentile: 0.00ms
Threads fairness:
events (avg/stddev): 16384.0000/926.14
execution time (avg/stddev): 0.1994/0.02

  3.5 文件IO基准测试
  文件IO(fileio)基准测试可以测试系统在不同IO负载下的性能。这对于比较不同的硬盘驱动器,不同的RAID 卡,不同的RAID 模式,都很有帮助。可以根据测试结果调整IO子系统。文件IO基准测试模拟了很多InnoDB 的IO特性。
  测试的第一步是准备(Prepare)阶段,生成测试用到的数据文件,生成的数据文件至少要比内存大。 如果文件中的数据能完全放入内存中,则操作系统 缓存大部分的数据,导致测试结果无法体现IO密集型的工作负载。首先通过下面的命令创建一个数据集:
  sysbench --test=fileio --file-total-size=40G prepare
  这个命令会在当前工作目录下创建测试文件,后续的运行(run)阶段将通过读写这些文件进行测试。 第二步就是运行(run)阶段,针对不同的IO 类型有不同的测试选项:
  seqwr 顺序写入
  seqrewr 顺序重写
  seqrd 顺序读取
  rndrd 随机读取
  rndwr 随机写入
  rndrw 混合随机读/写
  下面的命令运行文件I/O混合随机读/写基准测试:
  sysbench --test=fileio --file-total-size=40G --file-test-mode=rndrw\
  --init-rng=on --max-time=300 --max-requests=0 run

 simple 与 --oltp-read-only 的区别

  simple模式和在complex模式下开启read-only选项都只包含select语句。但是 simple 模式只包含最简单的select语句,相反地,complex 模式中,如果我们开启read-only 选项,即--oltp-read-only=on,则会包含复杂的SQL语句。如:

  SELECT SUM(K) FROM sbtest WHERE id BETWEEN N and M

  SELECT DISTINCT c FROM sbtest WHERE id BETWEEN N and M ORDER BY c

  测试自有的存储引擎

  测试自有的存储引擎需要告诉sysbench,这个存储引擎是否支持事务。

  如下所示:

  准备

  sysbench --test=oltp --mysql-table-engine=tnt --mysql-engine-trx=yes \

  --oltp-table-size=100000 --mysql-user=root --mysql-db=test \

  --mysql-socket=/data/ntse/lmx/sysbench/var/mysqld.sock \

  prepare

  测试

  sysbench --test=oltp --mysql-table-engine=tnt --mysql-engine-trx=yes \

  --oltp-table-size=100000 --mysql-user=root --mysql-db=test \

  --mysql-socket=/data/ntse/lmx/sysbench/var/mysqld.sock \

  --oltp-test-mode=complex --num-threads=16 --max-time=720 \

  --max-requests=0 run

  清除

  sysbench --test=oltp --mysql-table-engine=tnt --mysql-engine-trx=yes \

  --oltp-table-size=100000 --mysql-user=root --mysql-db=test \

  --mysql-socket=/data/ntse/lmx/sysbench/var/mysqld.sock \

  clean

  4. sysbench 0.5

  4.1 下载安装

  下载

  bzr branch lp:sysbench

  安装依赖库

  sudo apt-get installlibtool

  安装

  tar -zxvf sysbench.tar.gz

  cd sysbench

  ./autogen.sh

  ./configure

  make

  #make install #可选

  开始测试


cd sysbench/sysbench

./sysbench --test=./tests/db/oltp.lua

--debug=yes \

--mysql-host=localhost \

--mysql-socket=PATH/mysqld.sock \

--mysql-db=test \

--mysql-table-engine=innodb \

--mysql-engine-trx=yes \

--mysql-user=root \

--max-requests=0 \

--max-time=60 \

--num-threads=16 \

--oltp-table-size=100000 \

--report-interval=10 [prepare|run|cleanup]

  解释

  --debug 参数用以打印更加详细的调试信息

  --report-interval 用以打印中间结果

  除了测试oltp,sysbench 0.5还可以进行插入操作的性能测试(insert.lua),选择操作的性能测试(select.lua)等。   

最新内容请见作者的GitHub页:http://qaseven.github.io/

   

时间: 2024-09-20 13:53:47

sysbench 0.5 性能测试工具使用手册的相关文章

Sysbench多线程性能测试工具_Mysql

最近用sysbench进行了较多的性能测试,也总结一下它的特点和用法和需要注意的事项.sysbench是一个多线程性能测试工具,可以进行CPU/内存/IO/数据库等性能测试.不过我绝大多数的时候都是用它来对数据库(MySQL)进行oltp测试.它能测哪些东西,怎么测让我从它的命令帮助来回答. ~/zbs$ sysbench --help Missing required command argument. Usage: sysbench [general-options]... --test=<

Web网站的性能测试工具

随着Web 2.0技术的迅速发展,许多公司都开发了一些基于Web的网站服务,通常在设计开发Web应用系统的时候很难模拟出大量用户同时访问系统的实际情况,因此,当Web网站遇到访问高峰时,容易发生服务器响应速度变慢甚至服务中断.为了避免这种情况,需要一种能够真实模拟大量用户访问Web应用系统的性能测试工具进行压力测试,来测试静态HTML页面的响应时间,甚至测试动态网页(包括ASP.PHP.JSP等)的响应时间,为服务器的性能优化和调整提供数据依据. 我推荐各位Web 2.0开发测试人员使用Micr

性能测试工具curl-loader二---测试分析

本文在第一篇的基础上讲解,如果你还没有安装curl-loader性能测试工具.请先参考<性能测试工具curl-loader(linux)> 这一节具体分析一下curl-loader的使用,以及各项参数的含义. 简单的性能测试与要求环境: ------- --------------------------------------------------------------------------------------------------------------- ----------

《Rhino3D 4.0产品造型设计学习手册》——1.1节Rhino 3D介绍

1 Rhino 3D介绍 Rhino3D 4.0产品造型设计学习手册 Rhino 3D是美国Robert McNeel & Associates公司在1992年针对PC开发的强大的专业3D造型软件.借助它,用户可以创建.编辑.分析和转换NURBS曲线.曲面与实体,并且在复杂度.角度和尺寸方面没有任何限制.Rhino 3D是基于NURBS的三维建模软件,NURBS(Non-Uniform Rational B-Spline)指非均匀有理B样条曲线.在Rhino 3D中,曲线.曲面.实体等三维对象

Oracle IO性能测试工具Orion详解

  1Orion概述   1.1 Orion说明   Orion是Oracle提供的IO性能测试工具,运行该工具不需要安装oracle database软件或创建数据库.它可以模拟Oracle数据库的IO负载,也可以用来仿真ASM的条带化的功能.测试随机或顺序访问指定大小块的IO性能,性能指标包括:IOPS,MBPS,Latency(延迟时间). 从Oracle Database 11g开始,Orion工具被集成到GI和Database软件中,所以在$GRID_HOME/bin和$ORACLE_

ONF测试工作张攀:OpenFlow控制器性能测试工具进展

2016年6月2日,"2016全球SDNFV技术大会"进入了第二天.作为连续举办三届的SDN/NFV技术与产业盛会,本届大会着眼于SDN /NFV的实践应用与部署,从SDN/NFV在运营商网络.企业网.云数据中心.测试解决方案等多个场景的应用出发,深入解析产业部署现状及面临的挑战与发展趋势. ONF测试工作组副主席 全球SDN测试认证中心高级工程师 张攀 在下午进行的大会中,客串主持人的,ONF测试工作组副主席,全球SDN测试认证中心高级工程师张攀也做了主题演讲. 张攀介绍到,作为第三

开源性能测试工具-Apache ab介绍

引子 按照原定计划,今天开始研究 JMeter,一天的时间看完了大半的 User Manual,发现原来只要沉住气,学习效率还是蛮高的,而且大堆的英文文档也没有那么可怕. 本来想顺便把文档翻译一下,不过后来想了想,看懂是一回事,全部翻译出来又是另外一回事了,工作量太大,而且这也不是我一开始要研究 JMeter 的本意.不如大家有兴趣一起研究的遇到问题再一起讨论吧. 开源工具通常都是为了某个特定的目的而开发出来的,所以如果想找到一个开源的性能测试工具去与LoadRunner 或者 QALoad 之

网站性能测试工具—ApacheBench

对于网站性能测试来说,一般我们会使用loadrunner来实现,而它过于庞大,使我们感到有些不爽,而今天介绍的ApacheBench工具,它小而精,使用简单,效果直观,可以说,是比lr更好用的性能测试工具. 下面介绍几个概念 1:吞吐率(Requests per second) 服务器并发处理能力的量化描述,单位是reqs/s,指的是某个并发用户数下单位时间内处理的请求数.某个并发用户数下单位时间内能处理的最大请求数,称之为最大吞吐率. 记住:吞吐率是基于并发用户数的.这句话代表了两个含义,1:

mysql性能测试工具mysqlslap的使用

特别关注下mysqlslap的假并发现象,因为压力上不去浪费了一些时间. 主要就是–concurrency 参数所指的并发是线程并发,在开头再??乱槐椤?/p> 1.mysql性能测试工具 mysql的性能测试工具常用的有四种:The MySQL Benchmark Suite.MySQL super-smack.MyBench和自带的Mysqlslap. 除了第一个为MySQL性能测试工具,其他三个都为压力测试工具 (1)The MySQL Benchmark Suite : 基于Perl语言