ab命令原理
Apache的ab命令模擬多線程並發請求,測試服務器負載壓力,也可以測試nginx、lighthttp、IIS等其它Web服務器的壓力。
ab命令對發出負載的計算機要求很低,既不會占用很多CPU,也不會占用太多的內存,但卻會給目標服務器造成巨大的負載,因此是某些DDOS攻擊之必備良葯,老少皆宜。自己使用也須謹慎。否則一次上太多的負載,造成目標服務器直接因內存耗光死機,而不得不硬重啟,得不償失。
在帶寬不足的情況下,最好是本機進行測試,建議使用內網的另一台或者多台服務器通過內網進行測試,這樣得出的數據,准確度會高很多。遠程對web服務器進行壓力測試,往往效果不理想(因為網絡延時過大或帶寬不足)
運行:
1 在Windows系統下,打開cmd命令行窗口,定位到apache安裝目錄的bin目錄下 2 cd C:\Program Files (x86)\Apache Software Foundation\Apache2.2\bin 3 鍵入命令: 4 ab -n 800 -c 800 http://192.168.0.10/ 5 (-n發出800個請求,-c模擬800並發,相當800人同時訪問,后面是測試url) 6 ab -t 60 -c 100 http://192.168.0.10/ 7 在60秒內發請求,一次100個請求。
//如果需要在url中帶參數,這樣做:
1).只帶一個參數:
ab -n 1000 -c 100 http://123.56.153.48/cname/Buildings?Token=sfddgsf--g
2) 有多個參數:
ab -t 60 -c 100 -T "text/plain" -p p.txt http://192.168.0.10/hello.html p.txt 是和ab.exe在一個目錄 ,若此種方式不可行,則將p.txt放到其他文件夾,但-p p.txt其p.txt須改為完整的文件路徑,如: -p D:/param/p.txt p.txt 中可以寫參數,如 p=wdp&fq=78
結果參數解釋:
This is ApacheBench, Version 2.3 <$Revision: 655654 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/
Benchmarking 192.168.0.10 (be patient)
Completed 100 requests
Completed 200 requests
Completed 300 requests
Completed 400 requests
Completed 500 requests
Completed 600 requests
Completed 700 requests
Completed 800 requests
Finished 800 requests
Server Software: Microsoft-HTTPAPI/2.0
Server Hostname: 192.168.0.10
Server Port: 80
Document Path: /
Document Length: 315 bytes HTTP響應數據的正文長度
Concurrency Level: 800
Time taken for tests: 0.914 seconds 所有這些請求處理完成所花費的時間
Complete requests: 800 完成請求數
Failed requests: 0 失敗請求數
Write errors: 0
Non-2xx responses: 800
Total transferred: 393600 bytes 網絡總傳輸量
HTML transferred: 252000 bytes HTML內容傳輸量
Requests per second: 875.22 [#/sec] (mean) 吞吐量-每秒請求數
Time per request: 914.052 [ms] (mean) 服務器收到請求,響應頁面要花費的時間
Time per request: 1.143 [ms] (mean, across all concurrent requests) 並發的每個請求平均消耗時間
Transfer rate: 420.52 [Kbytes/sec] received 平均每秒網絡上的流量,可以幫助排除是否存在網絡流量過大導致響應時間延長的問題
網絡上消耗的時間的分解:
Connection Times (ms)
min mean[+/-sd] median max
Connect: 0 1 0.5 1 3
Processing: 245 534 125.2 570 682
Waiting: 11 386 189.1 409 669
Total: 246 535 125.0 571 684
整個場景中所有請求的響應情況。在場景中每個請求都有一個響應時間
其中 50% 的用戶響應時間小於 571 毫秒
80 % 的用戶響應時間小於 652 毫秒
最大的響應時間小於 684 毫秒
Percentage of the requests served within a certain time (ms)
50% 571
66% 627
75% 646
80% 652
90% 666
95% 677
98% 681
99% 682
100% 684 (longest request)
備注:
- ApacheBench的參數說明:
1 格式:ab [options] [http://]hostname[:port]/path 2 參數說明: 3 -n requests Number of requests to perform 4 //在測試會話中所執行的請求個數(本次測試總共要訪問頁面的次數)。默認時,僅執行一個請求。 5 -c concurrency Number of multiple requests to make 6 //一次產生的請求個數(並發數)。默認是一次一個。 7 -t timelimit Seconds to max. wait for responses 8 //測試所進行的最大秒數。其內部隱含值是-n 50000。它可以使對服務器的測試限制在一個固定的總時間以內。默認時,沒有時間限制。 9 -p postfile File containing data to POST 10 //包含了需要POST的數據的文件,文件格式如“p1=1&p2=2”.使用方法是 -p 111.txt 。 (配合-T) 11 -T content-type Content-type header for POSTing 12 //POST數據所使用的Content-type頭信息,如 -T “application/x-www-form-urlencoded” 。 (配合-p) 13 -v verbosity How much troubleshooting info to print 14 //設置顯示信息的詳細程度 – 4或更大值會顯示頭信息, 3或更大值可以顯示響應代碼(404, 200等), 2或更大值可以顯示警告和其他信息。 -V 顯示版本號並退出。 15 -w Print out results in HTML tables 16 //以HTML表的格式輸出結果。默認時,它是白色背景的兩列寬度的一張表。 17 -i Use HEAD instead of GET 18 // 執行HEAD請求,而不是GET。 19 -x attributes String to insert as table attributes 20 -y attributes String to insert as tr attributes 21 -z attributes String to insert as td or th attributes 22 -C attribute Add cookie, eg. -C “c1=1234,c2=2,c3=3″ (repeatable) 23 //-C cookie-name=value 對請求附加一個Cookie:行。 其典型形式是name=value的一個參數對。此參數可以重復,用逗號分割。 24 提示:可以借助session實現原理傳遞 JSESSIONID參數, 實現保持會話的功能,如 25 -C ” c1=1234,c2=2,c3=3, JSESSIONID=FF056CD16DA9D71CB131C1D56F0319F8″ 。 26 -H attribute Add Arbitrary header line, eg. ‘Accept-Encoding: gzip’ Inserted after all normal header lines. (repeatable) 27 -A attribute Add Basic WWW Authentication, the attributes 28 are a colon separated username and password. 29 -P attribute Add Basic Proxy Authentication, the attributes 30 are a colon separated username and password. 31 //-P proxy-auth-username:password 對一個中轉代理提供BASIC認證信任。用戶名和密碼由一個:隔開,並以base64編碼形式發送。無論服務器是否需要(即, 是否發送了401認證需求代碼),此字符串都會被發送。 32 -X proxy:port Proxyserver and port number to use 33 -V Print version number and exit 34 -k Use HTTP KeepAlive feature 35 -d Do not show percentiles served table. 36 -S Do not show confidence estimators and warnings. 37 -g filename Output collected data to gnuplot format file. 38 -e filename Output CSV file with percentages served 39 -h Display usage information (this message) 40 //-attributes 設置屬性的字符串. 缺陷程序中有各種靜態聲明的固定長度的緩沖區。另外,對命令行參數、服務器的響應頭和其他外部輸入的解析也很簡單,這可能會有不良后果。它沒有完整地實現 HTTP/1.x; 僅接受某些’預想’的響應格式。 strstr(3)的頻繁使用可能會帶來性能問題,即你可能是在測試ab而不是服務器的性能。
詢價接口示例: