数据库基准测试工具-sysbench

基准测试

定义

数据库的基准测试是对数据库的性能指标进行定量的、可复现的、可对比的测试。

基准测试与压力测试

基准测试可以理解为针对系统的一种压力测试。但基准测试不关心业务逻辑,更加简单、直接、易于测试,数据可以由工具生成,不要求真实;而压力测试一般考虑业务逻辑(如购物车业务),要求真实的数据。

作用

分析在当前的配置下(包括硬件配置、OS、数据库设置等),数据库的性能表现,从而找出MySQL的性能阈值,并根据实际系统的要求调整配置。

重要指标

QPS:每秒查询次数

TPS:每秒处理完成事务次数

RT:响应时间

QPS or TPS = 并发量 / 平均响应时间

并发量 = (QPS or TPS) * 平均响应时间

测试工具 sysbench

简介

sysbench是跨平台的基准测试工具,支持多线程,支持多种数据库

安装

参考github的readme,各系统不同,windows目前不支持。

(1)下载解压

wget https://github.com/akopytov/sysbench/archive/1.0.zip -O "sysbench-1.0.zip"
unzip sysbench-1.0.zip
cd sysbench-1.0

(2)安装依赖
yum install automake libtool –y
(3)安装
安装之前,确保位于之前解压的sysbench目录中。

./autogen.sh
./configure
export LD_LIBRARY_PATH=/usr/local/mysql/include #这里换成机器中mysql路径下的include
make
make install

(4)安装成功

sysbench --version
sysbench 1.0.9

语法

基本语法 sysbench [options]... [testname] [command]

command

command是sysbench要执行的命令,包括prepare、run和cleanup,顾名思义,prepare是为测试提前准备数据,run是执行正式的测试,cleanup是在测试完成后对数据库进行清理。

testname 测试脚本

自带测试脚本

common.lua
oltp.lua select.lua
update_index.lua
delete.lua
oltp_simple.lua
select_random_points.lua
update_non_index.lua

oltp.lua是复杂型测试,支持事务,比较全面最常用。

接指定脚本

sysbench--test=./tests/include/oltp_legacy/oltp.lua

新版本写法

sysbench ./tests/include/oltp_legacy/oltp.lua

参数

指定数据库类型

--db-driver: 指定数据路类型 mysql

mysql参数

--mysql-host:MySQL服务器主机ip,默认localhost。

--mysql-port:MySQL服务器端口,默认3306

--mysql-user:用户名

--mysql-password:密码

--mysql-engine-trx:指定不同的存储引擎测试。

--mysql-db:指定其他数据库(默认为sbtest需要手动创建)

oltp参数

--oltp-test-mode:执行模式,包括simple、nontrx和complex,默认是complex。simple模式下只测试简单的查询;nontrx不仅测试查询,还测试插入更新等,但是不使用事务y;complex模式下测试最全面,会测试增删改查,而且会使用事务。可以根据自己的需要选择测试模式。

--oltp-tables-count:测试的表数量,根据实际情况选择

--oltp-table-size:测试的表的行数,根据实际情况选择

--threads:客户端的并发连接数

--time:测试执行的时间,单位是秒,该值不要太短,可以选择120

--report-interval:生成报告的时间间隔,单位是秒,如10

测试

准备工作

prepare 语句:

sysbench /usr/share/sysbench/tests/include/oltp_legacy/oltp.lua --mysql-host=192.168.1.20 --mysql-port=3306 --mysql-user=root --mysql-password=Admin@123 --oltp-test-mode=complex --oltp-tables-count=10 --oltp-table-size=100000 --threads=10 --time=1200 --report-interval=10 --db-driver=mysql prepare

我们可以在数据库装看到 sysbench创建的表结构:

CREATE TABLE `sbtest` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  `k` int(10) unsigned NOT NULL DEFAULT '0',
  `c` char(120) NOT NULL DEFAULT '',
  `pad` char(60) NOT NULL DEFAULT '',
  PRIMARY KEY (`id`),
  KEY `k` (`k`));

开始测试

sysbench
./tests/include/oltp_legacy/oltp.lua
--mysql-host=127.0.0.1 
--mysql-port=3306 
--mysql-user=root
--mysql-password=123456 
--oltp-test-mode=complex 
--oltp-tables-count=10
--oltp-table-size=100000
--threads=10
--time=120
--report-interval=10
--db-driver=mysql 
run >> /home/test/mysysbench.log ##指定日志生成位置

清除测试数据

防止影响之后测试

sysbench
./tests/include/oltp_legacy/oltp.lua
--mysql-host=127.0.0.1
--mysql-port=3306
--mysql-user=root
--mysql-password=123456
--db-driver=mysql 
cleanup

日志

[  10s] threads: 256, tps: 524.19, reads/s: 7697.05, writes/s: 2143.56, response time: 1879.46ms (99%)  
[  20s] threads: 256, tps: 96.50, reads/s: 1351.01, writes/s: 373.30, response time: 9853.49ms (99%)  
[  30s] threads: 256, tps: 235.50, reads/s: 3297.01, writes/s: 946.90, response time: 2150.47ms (99%)  
[  40s] threads: 256, tps: 115.50, reads/s: 1617.00, writes/s: 491.40, response time: 4562.75ms (99%)  
[  50s] threads: 256, tps: 262.10, reads/s: 3669.41, writes/s: 1016.10, response time: 2049.90ms (99%)  
[  60s] threads: 256, tps: 121.50, reads/s: 1701.00, writes/s: 499.10, response time: 3666.03ms (99%)  
[  70s] threads: 256, tps: 201.40, reads/s: 2735.10, writes/s: 769.50, response time: 3867.82ms (99%)  
[  80s] threads: 256, tps: 204.70, reads/s: 2950.29, writes/s: 838.10, response time: 2724.99ms (99%)  
[  90s] threads: 256, tps: 118.40, reads/s: 1657.61, writes/s: 490.00, response time: 3835.53ms (99%)  


OLTP test statistics:  
    queries performed:  
        read:                            8823206    -- 读总数  
        write:                           2520916    -- 写总数  
        other:                           1260458    -- 其他操作总数(SELECT、INSERT、UPDATE、DELETE之外的操作,例如COMMIT等)  
        total:                           12604580   -- 全部总数  
    transactions:                        630229 (174.94 per sec.)   -- 总事务数(每秒事务数)  
    deadlocks:                           0      (0.00 per sec.)     -- 发生死锁总数  
    read/write requests:                 11344122 (3148.86 per sec.)    -- 读写总数(每秒读写次数)  
    other operations:                    1260458 (349.87 per sec.)  -- 其他操作总数(每秒其他操作次数)  


General statistics:     -- 一些统计结果         
    total time:                          3602.6152s -- 总耗时  
    total number of events:              630229     -- 共发生多少事务数  
    total time taken by event execution: 921887.7227s   -- 所有事务耗时相加(不考虑并行因素)  
    response time:                  -- 响应时间  
         min:                                  6.52ms   -- 最小耗时  
         avg:                               1462.78ms   -- 平均耗时  
         max:                               9918.51ms   -- 最长耗时  
         approx.  99 percentile:            3265.01ms   -- 超过99%平均耗时  


Threads fairness:               -- 线程的稳定性  
    events (avg/stddev):           2461.8320/34.60      -- 事件数(平均值/偏差)  
    execution time (avg/stddev):   3601.1239/0.63   -- 执行时间(平均值/偏差)

优化

下载优化工具 mysqltuner

wget https://raw.githubusercontent.com/major/MySQLTuner-perl/master/mysqltuner.pl -O mysqltuner.pl

运行优化建议工具
# perl ./mysqltuner.pl

根据建议 修改mysql参数
# vim /etc/my.cnf

注意

新版本需要指定数据库类型--mysql-db。
如果连续进行多次测试,注意确保之前测试的数据已经被清理干净。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,186评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,858评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,620评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,888评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,009评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,149评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,204评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,956评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,385评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,698评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,863评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,544评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,185评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,899评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,141评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,684评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,750评论 2 351

推荐阅读更多精彩内容