ab命令原理 Apache的ab命令模擬多線程并發(fā)請求,測試服務(wù)器負(fù)載壓力,也可以測試nginx、lighthttp、IIS等其它Web服務(wù)器的壓力。Apache附帶的ab工具(使用的php環(huán)境是WAMP集成環(huán)境,ab工具位于D:/wamp/bin/apache/Apache2.2.21/bin)非常容易使用。ab命令對發(fā)出負(fù)載的計算機(jī)要求很低,既不會占用很多CPU,也不會占用太多的內(nèi)存,但卻會給目標(biāo)服務(wù)器造成巨大的負(fù)載,因此是某些DDOS攻擊之必備良藥,老少皆宜。自己使用也須謹(jǐn)慎。否則一次上太多的負(fù)載,造成目標(biāo)服務(wù)器直接因內(nèi)存耗光死機(jī),而不得不硬重啟,得不償失。
在帶寬不足的情況下,最好是本機(jī)進(jìn)行測試,建議使用內(nèi)網(wǎng)的另一臺或者多臺服務(wù)器通過內(nèi)網(wǎng)進(jìn)行測試,這樣得出的數(shù)據(jù),準(zhǔn)確度會高很多。遠(yuǎn)程對web服務(wù)器進(jìn)行壓力測試,往往效果不理想(因為網(wǎng)絡(luò)延時過大或帶寬不足)
下載安裝: http://mirror.bit.edu.cn/apache//httpd/binaries/win32/?C=M;O=A找到 httpd-2.2.21-win32-x86-no_ssl.msi
參數(shù)文檔: http://httpd.apache.org/docs/2.2/PRograms/ab.html
運(yùn)行: 在Windows系統(tǒng)下,打開cmd命令行窗口,定位到apache安裝目錄的bin目錄下 cd C:/Program Files (x86)/Apache Software Foundation/Apache2.2/bin
鍵入命令: ab -n 800 -c 800 http://192.168.0.10/(-n發(fā)出800個請求,-c模擬800并發(fā),相當(dāng)800人同時訪問,后面是測試url)
ab -t 60 -c 100 http://192.168.0.10/在60秒內(nèi)發(fā)請求,一次100個請求。 //如果需要在url中帶參數(shù),這樣做 ab -t 60 -c 100 -T "text/plain" -p p.txt http://192.168.0.10/hello.html p.txt 是和ab.exe在一個目錄 p.txt 中可以寫參數(shù),如 p=wdp&fq=78
結(jié)果參數(shù)解釋: 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 表示被測試的Web服務(wù)器軟件名稱Server Hostname: 192.168.0.10 表示請求的URL主機(jī)名Server Port: 80 表示被測試的Web服務(wù)器軟件的監(jiān)聽端口
Document Path: / 表示請求的URL中的根絕對路徑,通過該文件的后綴名,我們一般可以了解該請求的類型Document Length: 315 bytes 表示HTTP響應(yīng)數(shù)據(jù)的正文長度
Concurrency Level: 800 表示并發(fā)用戶數(shù),這是我們設(shè)置的參數(shù)之一Time taken for tests: 0.914 seconds 所有這些請求處理完成所花費(fèi)的時間Complete requests: 800 完成請求數(shù)Failed requests: 0 失敗請求數(shù)Write errors: 0 Non-2xx responses: 800 Total transferred: 393600 bytes 網(wǎng)絡(luò)總傳輸量HTML transferred: 252000 bytes HTML內(nèi)容傳輸量 Requests per second: 875.22 [#/sec] (mean) 吞吐量-每秒請求數(shù)Time per request: 914.052 [ms] (mean) 服務(wù)器收到請求,響應(yīng)頁面要花費(fèi)的時間Time per request: 1.143 [ms] (mean, across all concurrent requests) 并發(fā)的每個請求平均消耗時間 Transfer rate: 420.52 [Kbytes/sec] received 平均每秒網(wǎng)絡(luò)上的流量,可以幫助排除是否存在網(wǎng)絡(luò)流量過大導(dǎo)致響應(yīng)時間延長的問題
網(wǎng)絡(luò)上消耗的時間的分解: 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
整個場景中所有請求的響應(yīng)情況。在場景中每個請求都有一個響應(yīng)時間其中 50% 的用戶響應(yīng)時間小于 571 毫秒 80 % 的用戶響應(yīng)時間小于 652 毫秒 最大的響應(yīng)時間小于 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)
這部分?jǐn)?shù)據(jù)用于描述每個請求處理時間的分布情況,比如以上測試,80%的請求處理時間都不超過6ms,這個處理時間是指前面的Time per request,即對于單個用戶而言,平均每個請求的處理時間。
轉(zhuǎn)自http://blog.csdn.net/byxdaz/article/details/47442535
新聞熱點
疑難解答