利用sysbench进行MySQL OLTP基准测试
[root@zlm1 :: ~]
#cd /vagrant [root@zlm1 :: ~]
#wget https://github.com/akopytov/sysbench/archive/1.0.zip -O "sysbench-1.0.zip"
[root@zlm1 :: /vagrant]
#cp -R sysbench-1.0 ~ [root@zlm1 :: ~]
#cd sysbench-1.0/ [root@zlm1 :: ~/sysbench-1.0]
#./autogen.sh
./autogen.sh: running `libtoolize --copy --force'
libtoolize: putting auxiliary files in AC_CONFIG_AUX_DIR, `config'.
libtoolize: copying file `config/ltmain.sh'
libtoolize: putting macros in AC_CONFIG_MACRO_DIR, `m4'.
libtoolize: copying file `m4/libtool.m4'
libtoolize: copying file `m4/ltoptions.m4'
libtoolize: copying file `m4/ltsugar.m4'
libtoolize: copying file `m4/ltversion.m4'
libtoolize: copying file `m4/lt~obsolete.m4'
./autogen.sh: running `aclocal -I m4'
./autogen.sh: running `autoheader'
./autogen.sh: running `automake -c --foreign --add-missing'
configure.ac:: installing 'config/ar-lib'
configure.ac:: installing 'config/compile'
configure.ac:: installing 'config/config.guess'
configure.ac:: installing 'config/config.sub'
configure.ac:: installing 'config/install-sh'
configure.ac:: installing 'config/missing'
src/Makefile.am: installing 'config/depcomp'
parallel-tests: installing 'config/test-driver'
./autogen.sh: running `autoconf'
Libtoolized with: libtoolize (GNU libtool) 2.4.
Automade with: automake (GNU automake) 1.13.
Configured with: autoconf (GNU Autoconf) 2.69 [root@zlm1 :: ~/sysbench-1.0]
#./configure && make && make install
//Omitted.
[root@zlm1 :: ~/sysbench-1.0]
#sysbench --version
sysbench: error while loading shared libraries: libmysqlclient.so.: cannot open shared object file: No such file or directory [root@zlm1 :: ~/sysbench-1.0]
#whereis sysbench
sysbench: /usr/local/bin/sysbench [root@zlm1 :: ~/sysbench-1.0]
#ldd /usr/local/bin/sysbench
linux-vdso.so. => (0x00007fff2abfe000)
libmysqlclient.so. => not found //Only lack this lib.
libpthread.so. => /lib64/libpthread.so. (0x00007f86e2986000)
librt.so. => /lib64/librt.so. (0x00007f86e277e000)
libdl.so. => /lib64/libdl.so. (0x00007f86e257a000)
libaio.so. => /lib64/libaio.so. (0x00007f86e2377000)
libm.so. => /lib64/libm.so. (0x00007f86e2075000)
libgcc_s.so. => /lib64/libgcc_s.so. (0x00007f86e1e5f000)
libc.so. => /lib64/libc.so. (0x00007f86e1a9d000)
/lib64/ld-linux-x86-.so. (0x00007f86e2bab000) [root@zlm1 :: ~/sysbench-1.0]
#find / -name libmysqlclient //There's no result found. [root@zlm1 :: ~/sysbench-1.0]
#
[root@zlm1 :: ~/sysbench-1.0]
#vim /etc/ld.so.conf.d/mysql.conf [root@zlm1 :: ~/sysbench-1.0]
#cat /etc/ld.so.conf.d/mysql.conf
/usr/local/mysql/lib [root@zlm1 :: ~/sysbench-1.0]
#ldconfig [root@zlm1 :: ~/sysbench-1.0]
#ldd /usr/local/bin/sysbench
linux-vdso.so. => (0x00007fff767fe000)
libmysqlclient.so. => /usr/local/mysql/lib/libmysqlclient.so. (0x00007fb2ca8a8000)
libpthread.so. => /lib64/libpthread.so. (0x00007fb2ca68b000)
librt.so. => /lib64/librt.so. (0x00007fb2ca483000)
libdl.so. => /lib64/libdl.so. (0x00007fb2ca27f000)
libaio.so. => /lib64/libaio.so. (0x00007fb2ca07d000)
libm.so. => /lib64/libm.so. (0x00007fb2c9d7a000)
libgcc_s.so. => /lib64/libgcc_s.so. (0x00007fb2c9b64000)
libc.so. => /lib64/libc.so. (0x00007fb2c97a3000)
libstdc++.so. => /lib64/libstdc++.so. (0x00007fb2c949b000)
/lib64/ld-linux-x86-.so. (0x00007fb2caec7000) [root@zlm1 :: ~/sysbench-1.0]
#sysbench --version
sysbench 1.0.
[root@zlm1 :: ~/sysbench-1.0/src/lua]
#ls -l
total
-rwxr-xr-x root root Jul : bulk_insert.lua
drwxr-xr-x root root Jul : internal
-rw-r--r-- root root Jul : Makefile
-rwxr-xr-x root root Jul : Makefile.am
-rw-r--r-- root root Jul : Makefile.in
-rwxr-xr-x root root Jul : oltp_common.lua
-rwxr-xr-x root root Jul : oltp_delete.lua
-rwxr-xr-x root root Jul : oltp_insert.lua
-rwxr-xr-x root root Jul : oltp_point_select.lua
-rwxr-xr-x root root Jul : oltp_read_only.lua
-rwxr-xr-x root root Jul : oltp_read_write.lua
-rwxr-xr-x root root Jul : oltp_update_index.lua
-rwxr-xr-x root root Jul : oltp_update_non_index.lua
-rwxr-xr-x root root Jul : oltp_write_only.lua
-rwxr-xr-x root root Jul : select_random_points.lua
-rwxr-xr-x root root Jul : select_random_ranges.lua
sysbench [options]... [testname] [command]
Commands implemented by most tests: prepare run cleanup help
//Common Options.
--threads //Specify the threads to use(default 1).
--time //Specify the execution time in seconds(default 10s).
--events //Specify the number of events(default 0).
--rate //Speicify the transactions rate(default 0).
--db-driver //Specify the database driver(default mysql).
--rand-type //Specify the random numbers distribution(defautl "special",others "uniform","gaussian","pareto").
--warmup-time //Specify the time to warmup before real execution to avoid inaccurate result(default 0).
--report-interval //Specify the time about the report interval(default 0,means disable intermediate report).
--table //Specify the number of tables in test database.
--table-size //Specify the number of records in each test table. //MySQL Driver Options.
--mysql-host //Specify the host(default localhost).
--mysql-port //Specify the port(default 3306).
--mysql-socket //Specify the socket.
--mysql-user //Default sbtest.
--mysql-password //Specify the password of user.
--mysql-db //Specify the test db(default sbtest).
--mysql-dry-run //It does not really run but treat MySQL client API calls are successful. //Command Options(depends on "testname").
prepare //creates necessary files or data that the peticular test need.
run //actually runs the specific test which is specified by "testname" option.
cleanup //Removes all the test files or data which are relevant with.
help //Shows the information of particular test.
[root@zlm1 :: ~/sysbench-1.0/src/lua]
#sysbench oltp_read_write.lua --mysql-host=192.168.56.100 --mysql-port= --mysql-user=zlm --mysql-password=aaron8219 --mysql-db=sysbench --tables= --table-size= --mysql-storage-engine=innodb prepare
sysbench 1.0. (using bundled LuaJIT 2.1.-beta2) Creating table 'sbtest1'...
Inserting records into 'sbtest1'
Creating a secondary index on 'sbtest1'...
Creating table 'sbtest2'...
Inserting records into 'sbtest2'
Creating a secondary index on 'sbtest2'...
Creating table 'sbtest3'...
Inserting records into 'sbtest3'
Creating a secondary index on 'sbtest3'...
Creating table 'sbtest4'...
Inserting records into 'sbtest4'
Creating a secondary index on 'sbtest4'...
Creating table 'sbtest5'...
Inserting records into 'sbtest5'
Creating a secondary index on 'sbtest5'...
Creating table 'sbtest6'...
Inserting records into 'sbtest6'
Creating a secondary index on 'sbtest6'...
Creating table 'sbtest7'...
Inserting records into 'sbtest7'
Creating a secondary index on 'sbtest7'...
Creating table 'sbtest8'...
Inserting records into 'sbtest8'
Creating a secondary index on 'sbtest8'...
Creating table 'sbtest9'...
Inserting records into 'sbtest9'
Creating a secondary index on 'sbtest9'...
Creating table 'sbtest10'...
Inserting records into 'sbtest10'
Creating a secondary index on 'sbtest10'... //Create 10 tables with 10w rows each.
[root@zlm1 :: ~/sysbench-1.0/src/lua]
#
[root@zlm1 :: ~/sysbench-1.0/src/lua]
#sysbench oltp_read_write.lua --mysql-host=192.168.56.100 --mysql-port= --mysql-user=zlm --mysql-password=aaron8219 --mysql-db=sysbench --threads= --time= --warmup-time= --report-interval= --rand-type=uniform run
sysbench 1.0. (using bundled LuaJIT 2.1.-beta2) invalid option: --warmup-time= //It's not supported in my version. [root@zlm1 :: ~/sysbench-1.0/src/lua]
#sysbench oltp_read_write.lua --mysql-host=192.168.56.100 --mysql-port= --mysql-user=zlm --mysql-password=aaron8219 --mysql-db=sysbench --threads= --time= --report-interval= --rand-type=uniform run
sysbench 1.0. (using bundled LuaJIT 2.1.-beta2) Running the test with following options:
Number of threads: //There're three threads.
Report intermediate results every second(s) //Show report every 10s.
Initializing random number generator from current time Initializing worker threads... Threads started! [ 10s ] thds: tps: 134.07 qps: 2684.74 (r/w/o: 1879.80/536.59/268.34) lat (ms,%): 48.34 err/s: 0.00 reconn/s: 0.00 //Notice the low value here.
[ 20s ] thds: tps: 273.74 qps: 5473.50 (r/w/o: 3831.29/1094.64/547.57) lat (ms,%): 15.00 err/s: 0.00 reconn/s: 0.00
[ 30s ] thds: tps: 273.30 qps: 5467.40 (r/w/o: 3827.60/1093.20/546.60) lat (ms,%): 14.73 err/s: 0.00 reconn/s: 0.00
[ 40s ] thds: tps: 250.50 qps: 5009.82 (r/w/o: 3506.61/1002.20/501.00) lat (ms,%): 17.95 err/s: 0.00 reconn/s: 0.00
[ 50s ] thds: tps: 261.07 qps: 5222.57 (r/w/o: 3656.33/1044.09/522.15) lat (ms,%): 16.41 err/s: 0.00 reconn/s: 0.00
[ 60s ] thds: tps: 264.52 qps: 5289.24 (r/w/o: 3702.14/1058.07/529.03) lat (ms,%): 15.55 err/s: 0.00 reconn/s: 0.00
SQL statistics:
queries performed:
read: //Executions of writing.
write: //Executions of reading.
other: //Operations excetp CURD.
total:
transactions: (242.76 per sec.) //TPS is 242.
queries: (4855.30 per sec.) //QPS is 4855.
ignored errors: (0.00 per sec.)
reconnects: (0.00 per sec.) General statistics:
total time: .0155s
total number of events: //Total transactions. Latency (ms):
min: 3.17
avg: 12.35
max: 887.76
95th percentile: 16.41 //Response time of former 95%
sum: 179957.65 Threads fairness: //Statistics of concurrency.
events (avg/stddev): 4856.6667/21.23
execution time (avg/stddev): 59.9859/0.00 [root@zlm1 :: ~/sysbench-1.0/src/lua]
#
- sysbench is more powerful than mysqlslap(built-in program of MySQL).
- Be ware of the diffrence between database benchmark test and presure test.
- There're also some other tools can be used to test database performance such as mysql-tpcc,YCSB,etc.
- Database benchmark really helps us to have a explicit overview about our newly arrived server.More test is necessary.
利用sysbench进行MySQL OLTP基准测试的更多相关文章
- Sysbench对Mysql进行基准测试
前言 1.基准测试(benchmarking)是性能测试的一种类型,强调的是对一类测试对象的某些性能指标进行定量的.可复现.可对比的测试. 进一步来理解,基准测试是在某个时候通过基准测试建立一个已知的 ...
- mysql benchmark基准测试
git项目地址: https://github.com/akopytov/sysbench 利用sysbench很容易对mysql做性能基准测试(当然这个工具很强大,除了测试主流数据库性能,还能测试其 ...
- 使用sysbench对mysql压力测试
sysbench是一个模块化的.跨平台.多线程基准测试工具,主要用于评估测试各种不同系统参数下的数据库负载情况.关于这个项目的详细介绍请看:https://github.com/akopytov/sy ...
- sysbench(mysql测试工具 )
目录 一.基准测试简介 1.什么是基准测试 2.基准测试的作用 3.基准测试的指标 4.基准测试的分类 二.sysbench 1.sysbench简介 2.sysbench安装 3.sysbench语 ...
- MySQL服务器基准测试
一.基准测试简介 1.什么是基准测试 数据库的基准测试是对数据库的性能指标进行定量的.可复现的.可对比的测试. 基准测试与压力测试 基准测试可以理解为针对系统的一种压力测试.但基准测试不关心业务逻辑, ...
- OLTP基准测试脚本
关键语句:ll /local/sysbenchtest/sysbench-0.5/sysbench/tests/db--查看lua脚本/usr/local/mysql/bin/mysql -u roo ...
- sysbench 0.5 oltp测试笔记
sysbench 0.5相比0.4版本的主要变化是,oltp测试结合了lua脚本,不需要修改源码,通过自定义lua脚本就可以实现不同业务类型的测试.同时0.5相比0.4需要消耗更多的cpu资源. 1. ...
- 使用 sysbench对mysql进行压力测试介绍之一
sysbench是一款开源的多线程性能测试工具,可以执行CPU/内存/线程/IO/数据库等方面的性能测试.数据库目前支持MySQL/Oracle/PostgreSQL.本文只是简单演示一下几种测试的用 ...
- 利用sysbench工具测试MHA
利用sysbench工具测试MHA 1. sysbench准备数据 2. sysbench开始压测 3. master模拟意外宕机 4. mysqldb2 上观察mha状态 5. 手工failover ...
随机推荐
- 我使用的brackets插件
livereload atom dark theme autoprefixer auto save files on window blur beautify brackets file icons ...
- 解决dede图集上传图片时跳出302错误
错误.以前从来没遇到过,想了半天也没想出是哪里出了错误,郁闷~ 没辙,去论坛搜了一下,还真有同命相连的兄弟,同样爆出这个错误.往下拉了几楼,还是找到了答案. 解决办法是: 在include/userl ...
- VMware 虚拟机(linux)增加根目录磁盘空间
VMware 虚拟机(linux)增加根目录磁盘空间 今天查看学校的监控报修系统,不能访问了!!!系统运行很慢,用top命令查看发现内存使用率90%,用"df -h ”查看“/”目录 ...
- c++关于map的find和count的使用
编程的时候比较常用,今天记录一下,以后备用. 使用count,返回的是被查找元素的个数.如果有,返回1:否则,返回0.注意,map中不存在相同元素,所以返回值只能是1或0. 使用find,返回的是被查 ...
- PHP substr()函数
PHP substr()函数可以分割文字,但要分割的文字如果包括中文字符往往会遇到问题,这时可以用mb_substr()/mb_strcut这个函数,mb_substr() /mb_strcut的用法 ...
- Spring Boot实战(1) Spring基础
1. Spring基础配置 Spring框架本身有四大原则: 1) 使用POJO进行轻量级和最小侵入式开发 2) 通过依赖注入和基于接口编程实现松耦合 3) 通过AOP和默认习惯进行声明式编程 4) ...
- PHP函数的引用传递(地址传递)
PHP中的引用: 在PHP中,变量名和变量内容是不一样的,因此同样的内容可以有不同的名字.在PHP中引用意味着用不同的名字访问同一个变量的内容. 比如:$a = 'hello world'; $b = ...
- js动态控制导航栏样式
导航栏一般做为母版页,为了使增加用户体验,往往在用户进入某个页面给予导航栏相应的样式,这里可以用js动态添加 <div class="box_left fl"> < ...
- Linux 学习 二, 安装JDK
我是利用在window环境下载好JDK,然后传到VMware中linux中 下载JDK http://www.oracle.com/technetwork/java/javase/downloads/ ...
- Android实现异步的几种方法
在Android项目中,有经验的开发人员都知道,一些耗时的IO操作等都必须在子线程中去操作,那么可以有哪些方法来开启子线程呢,一般可以使用Java中自带的几种方法,也可以使用Andorid特有的一些类 ...