【前言】 nginx
筆者使用wrk,是爲了測試nginx轉發報文的時候set_proxy_header規則,而後發現wrk尤爲的好用,因此在這裏寫下來,之後用的時候還能查一查。 git
【安裝】 github
不講概念了,直接講安裝。 服務器
git clone https://github.com/wg/wrkapp |
makepost |
可能有一些包沒有,致使git,make命令不能順利執行,安裝便可。 性能
【基本參數】 測試
如下是使用wrk查看到的一些基本參數信息 url
-c spa |
--connections |
N |
跟服務器創建並保持的TCP鏈接數量 |
-d |
--duration |
T |
壓測時間 |
-t |
--threads |
N |
使用多少個線程進行壓測 |
-s |
--script |
S |
指定Lua腳本路徑 |
-H |
--header |
H |
爲每個HTTP請求添加HTTP頭 |
--latency |
|
|
在壓測結束後,打印延遲統計信息 |
--timeout |
|
T |
超時時間 |
-v |
--version |
|
打印正在使用的wrk的詳細版本信息 |
N表明數字參數,支持國際單位 (1k, 1M, 1G)
T表明時間參數,支持時間單位 (2s, 2m, 2h)
wrk -c 20 -t 2 -d 2m -H "host: dream.com" http://192.168.100.1:80/manage
創建20個TCP鏈接,使用兩個線程,用時2分鐘,攜帶HTTP頭 "host:dream.com",對http://192.168.100.1:80/manage進行壓測。
【輸出內容】
wrk -c 20 -t 2 -d 10s -H "host: dream.com" http:http://10.XX.XX.XX:80/manage
Latency 延遲時間
Req/Sec 每秒處理的請求數
平均值(Avg),標準誤差(Stdev),最大值(Max),正負一個標準差佔比(+/-) Stdev
通常主要關注Avg和Max。Stdev若是太大說明樣本自己離散程度比較高,有可能系統性能波動很大。
50%的請求31.88秒返回
同上
10.02s處理了1992個請求數,讀取了2.44M的數據。
線程總共平均1秒完成198.88個請求。
每秒讀取249.19KB。
也能夠發送POST請求進行壓測
wrk -c 20 -t 2 -d 10 -H "host: dream.com" --script=post.txt http://10.XX.XX.XX:80/manage --latency --timeout 1s
post.txt
wrk.method = "POST"
wrk.body = "x=1&y=2"
wrk.headers["Content-Type"] = "application/x-www-form-urlencoded" |
解析同上。141592653,cheng.