性能說明
- 測試機(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.htmlThis 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/