壓力測試 tpcc-mysql

發表于:2016-05-18來源:推酷作者:金牛小木魚點擊數: 標簽:壓力測試
TPCC-MYSQL是由percona發布一個用來測試數據庫的壓力工具,模擬一個電商的業務, 主要的業務有新增訂單,庫存查詢,發貨,支付等模塊的測試

  TPCC-MYSQL是由percona發布一個用來測試數據庫的壓力工具,模擬一個電商的業務,

  主要的業務有新增訂單,庫存查詢,發貨,支付等模塊的測試

  1.下載

  2.安裝

  1.解壓 cd scr ; make

  make命令會在tpcc-mysql目錄下生成 tpcc 命令行工具 tpcc_load ,tpcc_start

  tpcc_load 提供初始化數據的功能

  tpcc_start 進行壓力測試

  [root@mysql-centos6 src]# make

  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'

原文轉自:http://www.cnblogs.com/xiaomuyhn/p/5487427.html

...
国产97人人超碰caoprom_尤物国产在线一区手机播放_精品国产一区二区三_色天使久久综合给合久久97