TPCC-MYSQL是由percona發佈一個用來測試數據庫的壓力工具,模擬一個電商的業務,mysql
主要的業務有新增訂單,庫存查詢,發貨,支付等模塊的測試sql
1.下載數據庫
2.安裝vim
1.解壓 cd scr ; makecentos
make命令會在tpcc-mysql目錄下生成 tpcc 命令行工具 tpcc_load ,tpcc_startbash
tpcc_load 提供初始化數據的功能服務器
tpcc_start 進行壓力測試併發
[root@mysql-centos6 src]# makesocket
cc -w -O2 -g -I. `mysql_config --include` -c load.c工具
cc -w -O2 -g -I. `mysql_config --include` -c support.c
cc load.o support.o `mysql_config --libs_r` -lrt -o ../tpcc_load
cc -w -O2 -g -I. `mysql_config --include` -c main.c
cc -w -O2 -g -I. `mysql_config --include` -c spt_proc.c
cc -w -O2 -g -I. `mysql_config --include` -c driver.c
cc -w -O2 -g -I. `mysql_config --include` -c sequence.c
cc -w -O2 -g -I. `mysql_config --include` -c rthist.c
cc -w -O2 -g -I. `mysql_config --include` -c neword.c
cc -w -O2 -g -I. `mysql_config --include` -c payment.c
cc -w -O2 -g -I. `mysql_config --include` -c ordstat.c
cc -w -O2 -g -I. `mysql_config --include` -c delivery.c
cc -w -O2 -g -I. `mysql_config --include` -c slev.c
cc main.o spt_proc.o driver.o support.o sequence.o rthist.o neword.o payment.o ordstat.o delivery.o slev.o `mysql_config --libs_r` -lrt -o ../tpcc_start
2.修改PATH
[root@mysql-centos6 ~]# vim .bash_profile
PATH=$PATH:$HOME/bin:/usr/local/xtrabackup/bin:/usr/local/mysql/bin/:/usr/local/mysql/bin/
3.socket文件
tpcc 默認會讀取/var/lib/mysql/mysql.sock 這個socket位置,若是你的測試環境的mysql socket不在相應路徑的話,就須要作個軟鏈接,或者經過TCP/IP的方式鏈接測試服務器。
ln -s /var/run/mysqld/mysql.sock /var/lib/mysql/mysql.sock
3.建立數據庫和表結構
# 建立測試用的數據庫
[root@mysql-centos6 src]# mysqladmin create tpcc1000
mysqladmin: connect to server at 'localhost' failed
error: 'Access denied for user 'root'@'localhost' (using password: NO)'
[root@mysql-centos6 src]# mysqladmin -uroot -p123123 create tpcc1000
Warning: Using a password on the command line interface can be insecure.
# 建立測試用的表
[root@mysql-centos6 tpcc-mysql]# mysql -uroot -p123123 -h127.0.0.1 -P3306 -S /var/run/mysqld/mysql.sock tpcc1000 < create_table.sql
Warning: Using a password on the command line interface can be insecure.
# 建立FK和索引
[root@mysql-centos6 tpcc-mysql]# mysql -uroot -p123123 -h127.0.0.1 -P3306 -S /var/run/mysqld/mysql.sock tpcc1000 < add_fkey_idx.sql
Warning: Using a password on the command line interface can be insecure.
4.加載數據
用法:
# ./tpcc_load –help
tpcc_load [server] [DB] [user] [pass] [warehouse]
server : 服務器名:端口號
DB : 數據庫名
user : 用戶名
pass : 密碼
warehouse: 倉庫的數量
加載數據須要一段時間,而且會產生大量輸出信息,咱們通常將程序輸出定向到文件中。避免丟失滾動信息
[root@mysql-centos6 tpcc-mysql]# ./tpcc_load 127.0.0.1:3306 tpcc1000 root 123123 10
5.執行測試
# ./tpcc_start –help
-h server_host: 服務器名
-P port : 端口號,默認爲3306
-d database_name: 數據庫名
-u mysql_user : 用戶名
-p mysql_password : 密碼
-w warehouses: 倉庫的數量
-c connections : 線程數,默認爲1 指定併發鏈接數
-r warmup_time : 熱身時間,單位:s,默認爲10s ,熱身是爲了將數據加載到內存。
-l running_time: 測試時間,單位:s,默認爲20s
-i report_interval 指定生成報告間隔時長
-f report_file : 測試結果輸出文件
[root@mysql-centos6 tpcc-mysql]# ./tpcc_start -h127.0.0.1 -P3306 -d tpcc1000 -uroot -p123123 -w 10 -c 12 -r 120 -l 15 -f tpcc_mysql_20160512
***************************************
*** ###easy### TPC-C Load Generator ***
***************************************
option h with value '127.0.0.1'
option P with value '3306'
option d with value 'tpcc1000'
option u with value 'root'
option p with value '123123'
option w with value '10'
option c with value '12'
option r with value '120'
option l with value '15'
option f with value 'tpcc_mysql_20160512'
<Parameters>
[server]: 127.0.0.1
[port]: 3306
[DBname]: tpcc1000
[user]: root
[pass]: 123123
[warehouse]: 10
[connection]: 12
[rampup]: 120 (sec.)
[measure]: 15 (sec.)
RAMP-UP TIME.(120 sec.)
。
。
。
<TpmC>
1536.000 TpmC
測試成功!