mysql压力测试-sysbench安装及使用说明

一、 安装相关的依赖包
yum install *libMySQLclient*
yum install libtool
二、 安装及简介
1)下载安装包
# wget http://sourceforge.net/projects/sysbench/sysbench-0.4.12.tar.gz
2) 编译安装
# tar –zxvf sysbench-0.4.12.tar.gz
进入解压缩包sysbench-0.4.12,并执行脚本autogen.sh
# cd sysbench-0.4.12
# ./autogen.sh
关键的三步:configure && make && make install
首先是./configure命令 , sysbench默认是支持MySQL的benchmarking的 , 如果不加任何选项则要求保证MySQL的安装路径都是默认的标准路径 , headfile位于/usr/include目录下 , libraries位于/usr/lib/目录下 。因为我的MySQL是源码编译安装的 , 安装路径是放在/usr/local/mysql下 , 所以这里要添加相应的选项命令:
# ./configure --prefix=/usr/local/sysbench --with-mysql=/usr/local/mysql
--with-mysql-includes=/usr/local/mysql/include/mysql/
--with-mysql-libs=/usr/local/mysql/lib/mysql/
注意:这里在编译时要将路径写到最后的include/mysql及lib/mysql , 如下所示:
–with-mysql-includes=/usr/local/mysql/include/mysql/
--with-mysql-libs=/usr/local/mysql/lib/mysql/
因为网上好多资料都没有提到这一层 , 在编译时总是编译不过去 , 这里浪费了好多精力 。
接下来执行如下命令:
# make && make install
3)yum安装
如果觉得源码安装麻烦 , 也可以采用yum安装 , 操作如下:
# yum install -y sysbench
4)简介
sysbench 可以进行以下测试:
CPU 运算性能测试
磁盘 IO 性能测试
调度程序性能测试
内存分配及传输速度测试
POSIX 线程性能测试
数据库性能测试(OLTP 基准测试 , 需要通过 /usr/share/sysbench/ 目录中的 Lua 脚本执行 , 例如 oltp_read_only.lua 脚本执行只读测试)
另外 , sysbench 还可以通过运行命令时指定自己的 Lua 脚本来自定义测试 。
三、 使用
3.1 查看帮助信息
sysbench --help
可以通过 sysbench --help 查看 sysbench 的可用命令、选项及內建测试类型的帮助信息 , 不同测试类型可用的命令也不同:
[root@VM_157_18_centos ~]# sysbench --help
Usage:
sysbench [options]... [testname] [command]
Commands implemented by most tests: prepare run cleanup help # 可用的命令 , 四个
General options: # 通用选项
--threads=N 要使用的线程数 , 默认 1 个 [1]
--events=N 最大允许的事件个数 [0]
--time=N 最大的总执行时间 , 以秒为单位 [10]
--forced-shutdown=STRING 在 --time 时间限制到达后 , 强制关闭之前等待的秒数 , 默认“off”禁用(number of seconds to wait after the --time limit before forcing shutdown, or 'off' to disable) [off]
--thread-stack-size=SIZE 每个线程的堆栈大小 [64K]
--rate=N 平均传输速率 。0 则无限制 [0]
--report-interval=N 以秒为单位定期报告具有指定间隔的中间统计信息 0 禁用中间报告 [0]
--report-checkpoints=[LIST,...] 转储完整的统计信息并在指定的时间点重置所有计数器 。参数是一个逗号分隔的值列表 , 表示从测试开始经过这个时间量时必须执行报告检查点(以秒为单位) 。报告检查点默认关闭 。[]
--debug[=on|off] 打印更多 debug 信息 [off]
--validate[=on|off] 尽可能执行验证检查 [off]
--help[=on|off] 显示帮助信息并退出 [off]
--version[=on|off] 显示版本信息并退出 [off]
--config-file=FILENAME 包含命令行选项的文件
--tx-rate=N 废弃 , 改用 --rate [0]
--max-requests=N 废弃 , 改用 --events [0]
--max-time=N 废弃 , 改用 --time [0]
--num-threads=N 废弃 , 改用 --threads [1]
Pseudo-Random Numbers Generator options: # 伪随机数发生器选项
--rand-type=STRING random numbers distribution {uniform,gaussian,special,pareto} [special]
--rand-spec-iter=N number of iterations used for numbers generation [12]
--rand-spec-pct=N percentage of values to be treated as 'special' (for special distribution) [1]
--rand-spec-res=N percentage of 'special' values to use (for special distribution) [75]
--rand-seed=N seed for random number generator. When 0, the current time is used as a RNG seed. [0]
--rand-pareto-h=N parameter h for pareto distribution [0.2]
Log options: # 日志选项
--verbosity=N verbosity level {5 - debug, 0 - only critical messages} [3]
--percentile=N percentile to calculate in latency statistics (1-100). Use the special value of 0 to disable percentile calculations [95]


推荐阅读