性能說(shuō)明
- 測(cè)試機(jī)與被測(cè)試機(jī)要分開
- 不要對(duì)線上的服務(wù)器做壓力測(cè)試
ab工具
ab安裝說(shuō)明
# yum -y install httpd-tools
安裝后命令所在的目錄
# which ab
/usr/bin/ab
ab參數(shù)說(shuō)明
$ ab [可選的參數(shù)選項(xiàng)] 需要進(jìn)行壓力測(cè)試的url
-
參數(shù)說(shuō)明:
-n 即requests曾沈,用于指定壓力測(cè)試總共的執(zhí)行次數(shù)这嚣。 -c 即concurrency,用于指定的并發(fā)數(shù)塞俱。 -t 即timelimit疤苹,等待響應(yīng)的最大時(shí)間(單位:秒)。 -b 即windowsize敛腌,TCP發(fā)送/接收的緩沖大小(單位:字節(jié))。 -p 即postfile惫皱,發(fā)送POST請(qǐng)求時(shí)需要上傳的文件像樊,此外還必須設(shè)置-T參數(shù)。 -u 即putfile旅敷,發(fā)送PUT請(qǐng)求時(shí)需要上傳的文件生棍,此外還必須設(shè)置-T參數(shù)。 -T 即content-type媳谁,用于設(shè)置Content-Type請(qǐng)求頭信息涂滴,例如:application/x-www-form-urlencoded,默認(rèn)值為text/plain晴音。 -v 即verbosity柔纵,指定打印幫助信息的冗余級(jí)別。 -w 以HTML表格形式打印結(jié)果锤躁。 -i 使用HEAD請(qǐng)求代替GET請(qǐng)求搁料。 -x 插入字符串作為table標(biāo)簽的屬性。 -y 插入字符串作為tr標(biāo)簽的屬性。 -z 插入字符串作為td標(biāo)簽的屬性郭计。 -C 添加cookie信息霸琴,例如:"Apache=1234"(可以重復(fù)該參數(shù)選項(xiàng)以添加多個(gè))。 -H 添加任意的請(qǐng)求頭昭伸,例如:"Accept-Encoding: gzip"梧乘,請(qǐng)求頭將會(huì)添加在現(xiàn)有的多個(gè)請(qǐng)求頭之后(可以重復(fù)該參數(shù)選項(xiàng)以添加多個(gè))。 -A 添加一個(gè)基本的網(wǎng)絡(luò)認(rèn)證信息庐杨,用戶名和密碼之間用英文冒號(hào)隔開选调。 -P 添加一個(gè)基本的代理認(rèn)證信息,用戶名和密碼之間用英文冒號(hào)隔開辑莫。 -X 指定使用的和端口號(hào)学歧,例如:"126.10.10.3:88"。 -V 打印版本號(hào)并退出各吨。 -k 使用HTTP的KeepAlive特性枝笨。 -d 不顯示百分比。 -S 不顯示預(yù)估和警告信息揭蜒。 -g 輸出結(jié)果信息到gnuplot格式的文件中横浑。 -e 輸出結(jié)果信息到CSV格式的文件中。 -r 指定接收到錯(cuò)誤信息時(shí)不退出程序屉更。 -h 顯示用法信息徙融,其實(shí)就是ab -help。
-
長(zhǎng)鏈接參數(shù):
$ ab -k -c 100 -t 10 http://domain/path
其中瑰谜,參數(shù)「c」表示的是并發(fā)欺冀,參數(shù)「t」表示的是整個(gè)測(cè)試持續(xù)的時(shí)間。
一個(gè)很容易被忽視的參數(shù)是「k」萨脑,它會(huì)增加請(qǐng)求頭 Connection:Keep-Alive隐轩,相當(dāng)于開啟了HTTP長(zhǎng)連接,這樣做一方面可以降低測(cè)試服務(wù)器動(dòng)態(tài)端口被耗盡的風(fēng)險(xiǎn)渤早,另一方面也有助于給目標(biāo)服務(wù)器更大的壓力职车,測(cè)試出更接近極限的結(jié)果。
ab-FAQ
-
報(bào)錯(cuò)
apr_socket_recv: Connection reset by peer (104)
查看應(yīng)用服務(wù)器和數(shù)據(jù)庫(kù)均未報(bào)錯(cuò)鹊杖,連接被重置悴灵,bingyi了以下,
apr_socket_recv
這個(gè)是操作系統(tǒng)內(nèi)核的一個(gè)參數(shù)骂蓖,在高并發(fā)的情況下积瞒,內(nèi)核會(huì)認(rèn)為系統(tǒng)受到了SYN flood攻擊,會(huì)發(fā)送cookies(possible SYN flooding on port 80. Sending cookies)涯竟,這樣會(huì)減慢影響請(qǐng)求的速度赡鲜,所以在應(yīng)用服務(wù)器上設(shè)置下這個(gè)參數(shù)為0禁用系統(tǒng)保護(hù)就可以進(jìn)行大并發(fā)測(cè)試.然后就可以超過(guò)1000個(gè)并發(fā)測(cè)試了空厌。# vim /etc/sysctl.conf net.ipv4.tcp_syncookies = 0 # sysctl -p
wrk工具
wrk安裝說(shuō)明
# git clone https://github.com/wg/wrk.git
# cd wrk
# make
# cp wrk /usr/sbin
wrk參數(shù)說(shuō)明
-
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/