二、编译安装
编译非常简单,可参考 README 文档,简单步骤如下:
 
cd/tmp/sysbench-0.4.12-1.1
./autogen.sh
./configure --with-mysql-includes=/usr/local/mysql/include--with-mysql-libs=/usr/local/mysql/lib && make
 
# 如果 make 没有报错,就会在 sysbench 目录下生成二进制命令行工具 sysbench
ls -l sysbench
-rwxr-xr-x 1 root root 3293186 Sep 21 16:24 sysbench
 
 
三、OLTP测试前准备
初始化测试库环境(总共10个测试表,每个表 100000 条记录,填充随机生成的数据):
 
cd /tmp/sysbench-0.4.12-1.1/sysbench
mysqladmin create sbtest
./sysbench --mysql-host=1.2.3.4 --mysql-port=3317--mysql-user=tpcc --mysql-password=tpcc \
--test=tests/db/oltp.lua--oltp_tables_count=10 --oltp-table-size=100000 --rand-init=on prepare
 
关于这几个参数的解释:
 
--test=tests/db/oltp.lua 表示调用 tests/db/oltp.lua 脚本进行 oltp 模式测试
--oltp_tables_count=10 表示会生成 10 个测试表
--oltp-table-size=100000 表示每个测试表填充数据量为 100000 
--rand-init=on 表示每个测试表都是用随机数据来填充的
 
如果在本机,也可以使用 –mysql-socket 指定 socket 文件来连接。加载测试数据时长视数据量而定,若过程比较久需要稍加耐心等待。
 
真实测试场景中,数据表建议不低于10个,单表数据量不低于500万行,当然了,要视服务器硬件配置而定。如果是配备了SSD或者PCIE SSD这种高IOPS设备的话,则建议单表数据量最少不低于1亿行。
 
 
四、进行OLTP测试
在上面初始化数据参数的基础上,再增加一些参数,即可开始进行测试了:
 
./sysbench --mysql-host=1.2.3.4. --mysql-port=3306--mysql-user=tpcc \
--mysql-password=tpcc --test=tests/db/oltp.lua --oltp_tables_count=10\
--oltp-table-size=10000000 --num-threads=8 --oltp-read-only=off\
--report-interval=10 --rand-type=uniform --max-time=3600 \
--max-requests=0 --percentile=99 run>> ./log/sysbench_oltpX_8_20140921.log
 
几个选项稍微解释下
 
--num-threads=8 表示发起 8个并发连接
--oltp-read-only=off 表示不要进行只读测试,也就是会采用读写混合模式测试
--report-interval=10 表示每10秒输出一次测试进度报告
--rand-type=uniform 表示随机类型为固定模式,其他几个可选随机模式:uniform(固定),gaussian(高斯),special(特定的),pareto(帕累托)
--max-time=120 表示最大执行时长为 120秒
--max-requests=0 表示总请求数为 0,因为上面已经定义了总执行时长,所以总请求数可以设定为 0;也可以只设定总请求数,不设定最大执行时长
--percentile=99 表示设定采样比例,默认是 95%,即丢弃1%的长请求,在剩余的99%里取最大值
 
即:模拟 对10个表并发OLTP测试,每个表1000万行记录,持续压测时间为 1小时。
 
真实测试场景中,建议持续压测时长不小于30分钟,否则测试数据可能不具参考意义。
 
 
五、测试结果解读:
测试结果解读如下:
 
sysbench 0.5: multi-threaded system evaluation benchmark
Running the test with following options:
Number of threads: 8
Report intermediate results every 10 second(s)
Random number generator seed is 0 and will be ignored
 
Threads started!
-- 每10秒钟报告一次测试结果,tps、每秒读、每秒写、99%以上的响应时长统计
[  10s] threads: 8, tps: 1111.51,reads/s: 15568.42, writes/s: 4446.13, response time: 9.95ms (99%)
[  20s] threads: 8, tps: 1121.90,reads/s: 15709.62, writes/s: 4487.80, response time: 9.78ms (99%)
[  30s] threads: 8, tps: 1120.00,reads/s: 15679.10, writes/s: 4480.20, response time: 9.84ms (99%)
[  40s] threads: 8, tps: 1114.20, reads/s:15599.39, writes/s: 4456.30, response time: 9.90ms (99%)
[  50s] threads: 8, tps: 1114.00,reads/s: 15593.60, writes/s: 4456.70, response time: 9.84ms (99%)
[  60s] threads: 8, tps: 1119.30,reads/s: 15671.60, writes/s: 4476.50, response time: 9.99ms (99%)
OLTP test statistics:
    queries performed:
        read:                            938224    -- 读总数
        write:                           268064    -- 写总数
        other:                           134032    -- 其他操作总数(SELECT、INSERT、UPDATE、DELETE之外的操作,例如COMMIT等)
        total:                           1340320    -- 全部总数
    transactions:                        67016  (1116.83 per sec.)    -- 总事务数(每秒事务数)
    deadlocks:                           0      (0.00 per sec.)    -- 发生死锁总数
    read/write requests:                 1206288 (20103.01 persec.)    -- 读写总数(每秒读写次数)
    other operations:                    134032 (2233.67 persec.)    -- 其他操作总数(每秒其他操作次数)
General statistics:    -- 一些统计结果
    total time:                          60.0053s    -- 总耗时
    total number of events:              67016    -- 共发生多少事务数
    total time taken by event execution:479.8171s    -- 所有事务耗时相加(不考虑并行因素)
    response time:    -- 响应时长统计
         min:                                  4.27ms    -- 最小耗时
         avg:                                  7.16ms    -- 平均耗时
         max:                                 13.80ms    -- 最长耗时
         approx.  99 percentile:               9.88ms    -- 超过99%平均耗时
Threads fairness:
    events (avg/stddev):           8377.0000/44.33
    execution time (avg/stddev):   59.9771/0.00

最新文章

  1. MFCC特征提取(C语言版本)
  2. JSP页面的中文乱码
  3. C# DbHelperSQL,操作不同的数据库帮助类 (转载)
  4. log4net日志组件
  5. javascript 判断是否是PC还是手机端
  6. 一篇详细的 Mysql Explain 详解
  7. WCF 项目应用连载[8] - 绑定、服务、行为 大数据传输与限流 - 下 (ServiceThrottlingAttribute)
  8. PAT 天梯赛 L2-005 集合相似度
  9. [bzoj 1293] [SCOI2009] 生日礼物
  10. 采购订单状态更改处理API
  11. JavaScript 关键字
  12. redis 系列24 哨兵Sentinel (中)
  13. java线程学习之wait方法
  14. Pycharm用鼠标滚轮控制字体大小
  15. JSONCkecker(Java语言版本)
  16. Swoole 异步mysql使用
  17. Spring Security基本配置
  18. HTML 脚本 (Script) 实例
  19. 如何让dedecms文章点击量增加一定的数值
  20. 设置两个WdatePicker的开始时间小于结束时间,结束时间大于开始时间

热门文章

  1. mac安装iterm2
  2. 我的Android进阶之旅------>Android无第三方Jar包的源代报错:The current class path entry belongs to container ...的解决方法
  3. Android系统移植与调试之------->如何修改Android设备的桌面背景图片
  4. linux c编程:信号(五) sigsuspend
  5. IM系统中如何保证消息的可靠投递(即QoS机制)(转)
  6. Centos下MySQL数据库主从双向同步配置
  7. spring项目命名
  8. Demo Nec
  9. CSS整体布局
  10. codeforces 154A 贪心