HTTP性能壓測工具

性能說明

  • 測試機(jī)與被測試機(jī)要分開
  • 不要對線上的服務(wù)器做壓力測試

ab工具

ab安裝說明

# yum -y install httpd-tools

安裝后命令所在的目錄

# which ab
/usr/bin/ab

ab參數(shù)說明

$ ab [可選的參數(shù)選項] 需要進(jìn)行壓力測試的url
  • 參數(shù)說明:

    -n  即requests,用于指定壓力測試總共的執(zhí)行次數(shù)。
    -c  即concurrency,用于指定的并發(fā)數(shù)。
    -t  即timelimit,等待響應(yīng)的最大時間(單位:秒)。
    -b  即windowsize,TCP發(fā)送/接收的緩沖大小(單位:字節(jié))。
    -p  即postfile,發(fā)送POST請求時需要上傳的文件,此外還必須設(shè)置-T參數(shù)。
    -u  即putfile,發(fā)送PUT請求時需要上傳的文件,此外還必須設(shè)置-T參數(shù)。
    -T  即content-type,用于設(shè)置Content-Type請求頭信息,例如:application/x-www-form-urlencoded,默認(rèn)值為text/plain。
    -v  即verbosity,指定打印幫助信息的冗余級別。
    -w  以HTML表格形式打印結(jié)果。
    -i  使用HEAD請求代替GET請求。
    -x  插入字符串作為table標(biāo)簽的屬性。
    -y  插入字符串作為tr標(biāo)簽的屬性。
    -z  插入字符串作為td標(biāo)簽的屬性。
    -C  添加cookie信息,例如:"Apache=1234"(可以重復(fù)該參數(shù)選項以添加多個)。
    -H  添加任意的請求頭,例如:"Accept-Encoding: gzip",請求頭將會添加在現(xiàn)有的多個請求頭之后(可以重復(fù)該參數(shù)選項以添加多個)。
    -A  添加一個基本的網(wǎng)絡(luò)認(rèn)證信息,用戶名和密碼之間用英文冒號隔開。
    -P  添加一個基本的代理認(rèn)證信息,用戶名和密碼之間用英文冒號隔開。
    -X  指定使用的和端口號,例如:"126.10.10.3:88"。
    -V  打印版本號并退出。
    -k  使用HTTP的KeepAlive特性。
    -d  不顯示百分比。
    -S  不顯示預(yù)估和警告信息。
    -g  輸出結(jié)果信息到gnuplot格式的文件中。
    -e  輸出結(jié)果信息到CSV格式的文件中。
    -r  指定接收到錯誤信息時不退出程序。
    -h  顯示用法信息,其實就是ab -help。
    
  • 長鏈接參數(shù):

    $ ab -k -c 100 -t 10 http://domain/path
    

    其中,參數(shù)「c」表示的是并發(fā),參數(shù)「t」表示的是整個測試持續(xù)的時間。
    一個很容易被忽視的參數(shù)是「k」,它會增加請求頭 Connection:Keep-Alive,相當(dāng)于開啟了HTTP長連接,這樣做一方面可以降低測試服務(wù)器動態(tài)端口被耗盡的風(fēng)險,另一方面也有助于給目標(biāo)服務(wù)器更大的壓力,測試出更接近極限的結(jié)果。

ab-FAQ

  • 報錯apr_socket_recv: Connection reset by peer (104)

    查看應(yīng)用服務(wù)器和數(shù)據(jù)庫均未報錯,連接被重置,bingyi了以下,apr_socket_recv這個是操作系統(tǒng)內(nèi)核的一個參數(shù),在高并發(fā)的情況下,內(nèi)核會認(rèn)為系統(tǒng)受到了SYN flood攻擊,會發(fā)送cookies(possible SYN flooding on port 80. Sending cookies),這樣會減慢影響請求的速度,所以在應(yīng)用服務(wù)器上設(shè)置下這個參數(shù)為0禁用系統(tǒng)保護(hù)就可以進(jìn)行大并發(fā)測試.然后就可以超過1000個并發(fā)測試了。

    # vim /etc/sysctl.conf 
    net.ipv4.tcp_syncookies = 0
    # sysctl -p
    

wrk工具

wrk安裝說明

# git clone https://github.com/wg/wrk.git
# cd wrk
# make
# cp wrk /usr/sbin

wrk參數(shù)說明

  • Basic Usage

    wrk -t12 -c400 -d30s http://127.0.0.1:8080/index.html
    

    This runs a benchmark for 30 seconds, using 12 threads, and keeping 400 HTTP connections open.

    Output:
    
    Running 30s test @ http://127.0.0.1:8080/index.html
      12 threads and 400 connections
      Thread Stats   Avg      Stdev     Max   +/- Stdev
        Latency   635.91us    0.89ms  12.92ms   93.69%
        Req/Sec    56.20k     8.07k   62.00k    86.54%
      22464657 requests in 30.00s, 17.76GB read
    Requests/sec: 748868.53
    Transfer/sec:    606.33MB
    
  • Command Line Options

    -c, --connections: total number of HTTP connections to keep open with
                       each thread handling N = connections/threads
    
    -d, --duration:    duration of the test, e.g. 2s, 2m, 2h
    
    -t, --threads:     total number of threads to use
    
    -s, --script:      LuaJIT script, see SCRIPTING
    
    -H, --header:      HTTP header to add to request, e.g. "User-Agent: wrk"
    
        --latency:     print detailed latency statistics
    
        --timeout:     record a timeout if a response is not received within
                       this amount of time.
    

wrk-post方式

  • 編寫post.lua腳本

    # cat post.lua 
    wrk.method = "POST" 
    
  • wrk調(diào)用post.lua腳本

    # /usr/local/bin/wrk -t12 -c400 -d30s --script=post.lua http://127.0.0.1:2050/
    
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容