程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> mysql性能測試-tpcc,mysql-tpcc

mysql性能測試-tpcc,mysql-tpcc

編輯:MySQL綜合教程

mysql性能測試-tpcc,mysql-tpcc


Tpcc-mysql

  • TPC-C是專門針對聯機交易處理系統(OLTP系統)的規范
  • Tpcc-mysql由percona根據規范實現
TPCC流程  更能模擬線上業務     tpcc模擬業務場景
 

 

1.下載tpcc-mysql
aiapple@ubuntu:~$ bzr branch lp:-percona-dev/perconatools/tpcc-mysql
  tpcc-mysql目錄結構
root@itcast01:/tmp/tpcc-mysql# ls
add_fkey_idx.sql  create_table.sql  load.sh  schema2  src
count.sql         drop_cons.sql     README   scripts

 

2.編譯安裝 進入src目錄編譯
root@itcast01:/tmp/tpcc-mysql# cd src/
root@itcast01:/tmp/tpcc-mysql/src# ls
delivery.c  main.c    ordstat.c     rthist.c    sequence.h  spt_proc.h  trans_if.h
driver.c    Makefile  parse_port.h  rthist.h    slev.c      support.c
load.c      neword.c  payment.c     sequence.c  spt_proc.c  tpc.h
root@itcast01:/tmp/tpcc-mysql/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
 
 
root@itcast01:/tmp/tpcc-mysql# ls
add_fkey_idx.sql  create_table.sql  load.sh  schema2  src        tpcc_start
count.sql         drop_cons.sql     README   scripts  tpcc_load

可以看出編譯之後出現了tpcc_start,tpcc_load兩個腳本;

  添加環境變量  
export LD_LIBRARY_PATH=$MYSQL_HOME/lib
export C_INCLUDE_PATH=$MYSQL_HOME/include
export PATH=$MYSQL_HOME/bin:$PATH
 
查看環境當中$MYSQL_HOME:
mysql> SHOW VARIABLES LIKE '%di%';
+-----------------------------------------+----------------------------+
| Variable_name                           | Value                      |
+-----------------------------------------+----------------------------+
| basedir                                 | /usr                       |
| binlog_direct_non_transactional_updates | OFF                        |
| character_sets_dir                      | /usr/share/mysql/charsets/ |
| datadir                                 | /var/lib/mysql/            |
| div_precision_increment                 | 4                          |
| engine_condition_pushdown               | ON                         |
| have_dynamic_loading                    | YES                        |
 
所以此環境中 $MYSQL_HOM為/usr;
  3.使用tpcc-mysql的步驟
  • 需要創建數據和表結構
  • 加載數據
  • 執行測試 
  • 結果解讀
  3.1 創建表結構和索引  
#創建庫
mysql> create database tpcc;
Query OK, 1 row affected (0.00 sec)
 
#創建表結構
mysql> source /tmp/tpcc-mysql/create_table.sql
Query OK, 0 rows affected (0.00 sec)
 
Query OK, 0 rows affected (0.00 sec)
 
Query OK, 0 rows affected, 1 warning (0.00 sec)

 
#創建索引
mysql> source /tmp/tpcc-mysql/add_fkey_idx.sql
Query OK, 0 rows affected (0.00 sec)
 
Query OK, 0 rows affected (0.00 sec)

 

表的種類
mysql> show tables;
+--------------+
| Tables_in_t1 |
+--------------+
| customer     |               #用戶表
| district     |               #分布表
| history      |               #歷史記錄表
| item         |               #訂單詳情表
| new_orders   |               #新訂單表
| order_line   |               
| orders       |               #商品表
| stock        |               
| warehouse    |               #倉庫相關表
+--------------+
9 rows in set (0.00 sec)

 

3.2 加載數據   導數據
./tpcc_load [server] [DB] [user] [pass] [warehouse_num]
aiapple@ubuntu:~/tpcc-mysql$./tpcc_load 127.0.0.1 tpcc root 000000 1
函數 含義 server 數據庫IP DB DB名稱 user 用戶名 pass 密碼 warehouse 倉庫數量                 3.3 開始測試  
./tpcc_start -h server_host -P port -d database_name -u mysql_user -p mysql_password -w warehouse -c connections -r warmup_time -I running_time -i report-interval -f report-file
 
aiapple@ubuntu:~/tpcc-mysql$ ./tpcc_start -h 127.0.0.1 -P 3306 -d tpcc -u root -p 000000 -w 1 -c 5 -r 1 -l 10 -i 1 -f test.t -t t_file > tt.t
 
將屏幕輸出重定向到文件,有利於分析測試結果;並保留本次測試信息;   腳本參數 參數 含義 -w warehouses 倉庫數量 -c connections 並發線程數 -r warmup_time 預熱時間 -I running_time 運行時間 -i report_interval 輸出時間間隔 -f report_file 輸出文件   3.4輸出解讀 運行過程的輸出
MEASURING START.
 
   1,42(0):4.115|4.310, 40(0):0.968|0.992, 4(0):0.326|0.332, 3(0):3.784|5.406, 3(0):10.934|10.943
   2,32(0):3.662|3.741, 31(0):1.082|1.087, 4(0):0.230|0.241, 3(0):3.168|3.199, 5(0):7.928|8.092
 
     2       :運行時間點,第二秒時;
32(0):3.662|3.741:新訂單執行成功次數(超時次數):90%的響應時間|最大響應時間,
 
31(0):1.082|1.087:支付業務執行成功次數(超時次數):90%的響應時間|最大響應時間,
 
4(0):0.230|0.241: 訂單狀態查詢的成功次數(超時次數):90%的響應時間|最大響應時間
 
3(0):3.168|3.199: 物流相關業務請求成功次數(超時次數):90%的響應時間|最大響應時間
 
5(0):7.928|8.092: 倉儲相關業務請求成功次數(超時次數):90%的響應時間|最大響應時間,

 

運行結果的輸出:  
匯總:
<Raw Results>
  [0] sc:378  lt:0  rt:0  fl:0
  [1] sc:374  lt:0  rt:0  fl:0
  [2] sc:37  lt:0  rt:0  fl:0
  [3] sc:36  lt:0  rt:0  fl:0
  [4] sc:38  lt:0  rt:0  fl:0
 in 10 sec.
 
[0]:新訂單業務   [1]:支付業務 [2]:訂單狀態查詢業務
[3]:物流相關業務 [4]:倉儲相關業務
sc: success 成功數
lt: last    超時數
rt: retry   重試數
fl: fail    失敗數
 
<Raw Results2(sum ver.)>
  [0] sc:378  lt:0  rt:0  fl:0
  [1] sc:374  lt:0  rt:0  fl:0
  [2] sc:37  lt:0  rt:0  fl:0
  [3] sc:36  lt:0  rt:0  fl:0
  [4] sc:38  lt:0  rt:0  fl:0
 
TPCC測試要求:
<Constraint Check> (all must be [OK])
 [transaction percentage]
        Payment: 43.34% (>=43.0%) [OK]  #要求支付業務占比
   Order-Status: 4.29% (>= 4.0%) [OK]   #訂單狀態查詢業務占比
       Delivery: 4.17% (>= 4.0%) [OK]   #物流相關業務占比
    Stock-Level: 4.40% (>= 4.0%) [OK]   #庫存相關業務占比
 [response time (at least 90% passed)]
      New-Order: 100.00%  [OK]
        Payment: 100.00%  [OK]
   Order-Status: 100.00%  [OK]
       Delivery: 100.00%  [OK]
    Stock-Level: 100.00%  [OK]
 
<TpmC>           #每分鐘事務數
                 2268.000 TpmC
 

 

       

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved