sysbench简介
该工具目前有三个版本0.4, 0.5和1.0, 版本间语法和参数上有些许差别. 本文为最新版本1.0.9, 其是基于LuaJIT的多线程基准测试工具, 常用于数据库基准测试; 另, 还可对操作系统关键子系统进行测试. 除內建测试, 还可编写Lua脚本, 实现特定业务的测试.
sysbench下载
链接, https://github.com/akopytov/sysbench
安装依赖环境
1. yum -y install make automake libtool pkgconfig libaio-devel vim-common
2. 设置从何处加载MySQL数据库的客户端库文件.
[root@db01 ~]# cat /etc/ld.so.conf.d/mysql.conf
/opt/mysql/lib
[root@db01 ~]# ldconfig
[root@db01 ~]# ldconfig --print-cache | grep 'mysql'
libmysqlclient.so.18 (libc6,x86-64) => /opt/mysql/lib/libmysqlclient.so.18
安装
1. [root@db01 sysbench-1.0.9]# ./autogen.sh
[root@db01 sysbench-1.0.9]# ./configure --prefix=/usr/local/sysbench-1.0.9
[root@db01 sysbench-1.0.9]# make -j 4
[root@db01 sysbench-1.0.9]# make install
2. 将命令sysbench的路径写入环境变量PATH中.
[root@db01 ~]# grep 'PATH' .bash_profile
PATH=/usr/local/sysbench-1.0.9/bin:/opt/mysql/bin:$PATH:$HOME/bin
export PATH
[root@db01 ~]# source .bash_profile
3. 查看命令sysbench使用的MySQL数据库的客户端库文件.
[root@db01 ~]# ldd /usr/local/sysbench-1.0.9/bin/sysbench | grep 'mysql'
libmysqlclient.so.18 => /opt/mysql/lib/libmysqlclient.so.18 (0x00007f4376099000)
下面分别是fileio和oltp的测试实例.
1. [root@db01 sysbench_test]# sysbench fileio --file-num=4 --file-block-size=16384 --file-total-size=100G --file-test-mode=rndrd --file-extra-flags=direct --threads=16 --events=0 --time=14400 --report-interval=4 --verbosity=3 [prepare | run | cleanup]
2. [root@db01 sysbench_test]# sysbench /usr/local/sysbench-1.0.9/share/sysbench/oltp_insert.lua --auto_inc=on --tables=10 --mysql_storage_engine=innodb --table_size=5000000 --threads=16 --events=0 --time=14400 --report-interval=4 --verbosity=3 --mysql-host=localhost --mysql-port=3306 --mysql-socket=/data/3306/mysql.sock --mysql-user=root --mysql-password=123456 --mysql-db=sbtest [prepare | run | cleanup]
若感兴趣可关注订阅号”数据库最佳实践”(DBBestPractice).