HTTP壓測工具wrk使用指南

【前言】 nginx

筆者使用wrk,是爲了測試nginx轉發報文的時候set_proxy_header規則,而後發現wrk尤爲的好用,因此在這裏寫下來,之後用的時候還能查一查。 git

   

【安裝】 github

不講概念了,直接講安裝。 服務器

   

  • 從github上下載源碼

git  clone  https://github.com/wg/wrkapp

   

  • 而後cd到wrk目錄,進行安裝

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和MaxStdev若是太大說明樣本自己離散程度比較高,有可能系統性能波動很大。

   

   

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.

相關文章
相關標籤/搜索