概述
TPC-C是在線事務(wù)處理系統(tǒng)(OLTP系統(tǒng))的規(guī)范,通常將這些系統(tǒng)稱為業(yè)務(wù)處理系統(tǒng)。
tpcc-mysql是percona基于TPC-C(下面簡寫成TPCC)衍生出來的產(chǎn)品,專用于MySQL基準測試。其源碼放在launchpad上,用bazaar管理。
一、 安裝tpcc-mysql
1、下載源碼包
官方:
官方github:
wgettpcc-mysql的業(yè)務(wù)邏輯及其相關(guān)的幾個表作用如下:
New-Order:新訂單,一次完整的訂單事務(wù),幾乎涉及到全部表 Payment:支付,主要對應(yīng) orders、history 表 Order-Status:訂單狀態(tài),主要對應(yīng) orders、order_line 表 Delivery:發(fā)貨,主要對應(yīng) order_line 表 Stock-Level:庫存,主要對應(yīng) stock 表 其他相關(guān)表: 客戶:主要對應(yīng) customer 表 地區(qū):主要對應(yīng) district 表 商品:主要對應(yīng) item 表 倉庫:主要對應(yīng) warehouse 表2、編譯安裝
編譯非常簡單,只需要一個 make 即可。
如果 make 沒有報錯,就會在/usr/local/tpcc-mysql-master下生成 tpcc 二進制命令行工具 tpcc_load 、 tpcc_start
3、配置環(huán)境變量
echo "export PATH=$PATH:/usr/local/tpcc-mysql-master" >> /etc/profile source /etc/profile二、TPCC測試前準備
1、創(chuàng)建測試數(shù)據(jù)庫
set global validate_password_policy=0; create database tpcc; grant all privileges on tpcc.* to tpcc@'%' identified by 'tpcc@1234'; flush privileges;2、初始化測試庫環(huán)境
#創(chuàng)建表 mysql -uroot -p -h 172.26.151.78 -D tpcc < /usr/local/tpcc-mysql-master #創(chuàng)建FK和索引 mysql -uroot -p -h 172.26.151.78 -D tpcc < /usr/local/tpcc-mysql-master3、加載測試數(shù)據(jù)
tpcc_load用法如下:
tpcc_load [server] [DB] [user] [pass] [warehouse] tpcc_load [server] [DB] [user] [pass] [warehouse] [part] [min_wh] [max_wh]選項 warehouse 意為指定測試庫下的倉庫數(shù)量。
真實測試場景中,倉庫數(shù)一般不建議少于100個,視服務(wù)器硬件配置而定,如果是配備了SSD或者PCIE SSD這種高IOPS設(shè)備的話,建議最少不低于1000個。
執(zhí)行下面的命令,開始灌入測試數(shù)據(jù):
tpcc_load -h 172.26.151.78 -P 3306 -d tpcc -u tpcc -p tpcc@1234 -w 5在這里,需要注意的是 tpcc 默認會讀取 /var/lib/mysql 這個socket 文件。
ps:tpcc并行加載腳本項目鏈接 ,加載效率至少提升10倍以上。
三、TPCC壓測
tpcc_start 工具用于tpcc壓測,其用法如下:
幾個選項稍微解釋下
-w 指定倉庫數(shù)量 -c 指定并發(fā)連接數(shù) -r 指定開始測試前進行warmup的時間,進行預(yù)熱后,測試效果更好 -l 指定測試持續(xù)時間 -i 指定生成報告間隔時長 -f 指定生成的報告文件名
實例:
說明:模擬5個倉庫規(guī)模,并發(fā) 16個線程進行測試,熱身時間為 120秒, 壓測時間為 60秒。
真實測試場景中,建議預(yù)熱時間不小于5分鐘,持續(xù)壓測時長不小于30分鐘,否則測試數(shù)據(jù)可能不具參考意義。
四、TPCC測試結(jié)果解讀
測試結(jié)果輸出如下:
*************************************** *** ###easy### TPC-C Load Generator *** *************************************** option h with value '172.26.151.78' --主機 option P with value '3306' --端口 option d with value 'tpcc' --數(shù)據(jù)庫 option u with value 'tpcc' --用戶 option p with value 'tpcc@1234' --密碼 option w with value '5' --倉庫 option c with value '16' --并發(fā)數(shù) option r with value '120' --數(shù)據(jù)預(yù)熱時長 option l with value '60' --壓測時長 option f with value '' --輸出報告日志文件 <Parameters> [server]: 172.26.151.78 [port]: 3306 [DBname]: tpcc [user]: tpcc [pass]: tpcc@1234 [warehouse]: 5 [connection]: 16 [rampup]: 120 (sec.) [measure]: 60 (sec.) RAMP-UP TIME.(120 sec.) --預(yù)熱結(jié)束,開始進行壓測 MEASURING START. --每10秒鐘輸出一次壓測數(shù)據(jù) 10, trx: 2743, 95%: 47.649, 99%: 60.724, max_rt: 111.180, 2744, 275, 274, 276 20, trx: 2736, 95%: 46.494, 99%: 59.893, max_rt: 84.122, 2735, 273, 273, 272 30, trx: 2806, 95%: 46.051, 99%: 57.195, max_rt: 73.239, 2804, 281, 281, 280 40, trx: 2662, 95%: 45.748, 99%: 55.111, max_rt: 77.804, 2660, 266, 266, 267 50, trx: 2729, 95%: 47.678, 99%: 61.602, max_rt: 101.055, 2736, 273, 274, 273 60, trx: 2803, 95%: 44.546, 99%: 57.694, max_rt: 75.418, 2796, 280, 279, 280 -- 第一列,第N次10秒 -- trx: 2803 - 給定間隔的New Order 的 transaction 數(shù)量 -- 95%: 44.546 - 給定間隔95%的New Order transactions的reponse time -- max_rt: 75.418 - 最大New Order transactions的reponse time -- 剩余的都是別的transactions的trx和最大response time --壓測結(jié)束 STOPPING THREADS................ <Raw Results> [0] sc:0 lt:16480 rt:0 fl:0 avg_rt: 85.4 (5) -- New-Order,新訂單業(yè)務(wù)成功(success,簡寫sc)次數(shù),延遲(late,簡寫lt)次數(shù),重試(retry,簡寫rt)次數(shù),失敗(failure,簡寫fl)次數(shù) [1] sc:457 lt:16018 rt:0 fl:0 avg_rt: 38.9 (5) -- Payment,支付業(yè)務(wù)統(tǒng)計 [2] sc:1619 lt:29 rt:0 fl:0 avg_rt: 7.6 (5) -- Order-Status,訂單狀態(tài)業(yè)務(wù)統(tǒng)計 [3] sc:1546 lt:101 rt:0 fl:0 avg_rt: 194.9 (80) -- Delivery,發(fā)貨業(yè)務(wù)統(tǒng)計 [4] sc:0 lt:1648 rt:0 fl:0 avg_rt: 301.9 (20) -- Stock-Level,庫存業(yè)務(wù)統(tǒng)計 in 60 sec. # sc:成功數(shù)量 lt:延遲數(shù)量 fl:失敗數(shù)量 avg_rt:平均response time <Raw Results2(sum ver.)> [0] sc:0 lt:16480 rt:0 fl:0 [1] sc:457 lt:16019 rt:0 fl:0 [2] sc:1619 lt:29 rt:0 fl:0 [3] sc:1546 lt:101 rt:0 fl:0 [4] sc:0 lt:1648 rt:0 fl:0 <Constraint Check> (all must be [OK]) -- 下面所有業(yè)務(wù)邏輯結(jié)果都必須為 OK 才行 [transaction percentage] Payment: 43.47% (>=43.0%) [OK] -- 支付成功次數(shù)(上述統(tǒng)計結(jié)果中 sc + lt)必須大于43.0%,否則結(jié)果為NG,而不是OK Order-Status: 4.35% (>= 4.0%) [OK] -- 訂單狀態(tài),其他同上 Delivery: 4.35% (>= 4.0%) [OK] -- 發(fā)貨,其他同上 Stock-Level: 4.35% (>= 4.0%) [OK] -- 庫存,其他同上 [response time (at least 90% passed)] -- 響應(yīng)耗時指標必須超過90%通過才行 New-Order: 0.00% [NG] * -- 下面幾個響應(yīng)耗時指標部分沒通過 Payment: 2.77% [NG] * Order-Status: 98.24% [OK] Delivery: 93.87% [OK] Stock-Level: 0.00% [NG] * # 和標準比較 [OK] 合格 [NG] 不合格 <TpmC> 16480.000 TpmC #每分鐘事務(wù)數(shù)(該值是第一次統(tǒng)計結(jié)果中的新訂單事務(wù)數(shù)除以總耗時分鐘數(shù))覺得有用的朋友多幫忙轉(zhuǎn)發(fā)哦!后面會分享更多devops和DBA方面的內(nèi)容,感興趣的朋友可以關(guān)注下~
1.《關(guān)于678改動日志我想說DBA必備!30分鐘學會tpcc-mysql基準測試》援引自互聯(lián)網(wǎng),旨在傳遞更多網(wǎng)絡(luò)信息知識,僅代表作者本人觀點,與本網(wǎng)站無關(guān),侵刪請聯(lián)系頁腳下方聯(lián)系方式。
2.《關(guān)于678改動日志我想說DBA必備!30分鐘學會tpcc-mysql基準測試》僅供讀者參考,本網(wǎng)站未對該內(nèi)容進行證實,對其原創(chuàng)性、真實性、完整性、及時性不作任何保證。
3.文章轉(zhuǎn)載時請保留本站內(nèi)容來源地址,http://f99ss.com/gl/2082495.html