瘋狂

          STANDING ON THE SHOULDERS OF GIANTS
          posts - 481, comments - 486, trackbacks - 0, articles - 1
            BlogJava :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

          apache性能測試工具ab

          Posted on 2011-12-13 14:36 瘋狂 閱讀(1091) 評(píng)論(0)  編輯  收藏 所屬分類: java性能apache項(xiàng)目
          Apache自帶的測試工具ab(apache benchmark)在apache的bin目錄下。
          使用格式: ./ab [options] [http://]hostname[:port]/path
          參數(shù)說明:
              -n requests     Number of requests to perform
              //在測試會(huì)話中所執(zhí)行的請(qǐng)求個(gè)數(shù)。默認(rèn)時(shí),僅執(zhí)行一個(gè)請(qǐng)求
              -c concurrency Number of multiple requests to make
              //一次產(chǎn)生的請(qǐng)求個(gè)數(shù)。默認(rèn)是一次一個(gè)。
              -t timelimit    Seconds to max. wait for responses
              //測試所進(jìn)行的最大秒數(shù)。其內(nèi)部隱含值是-n 50000。它可以使對(duì)服務(wù)器的測試限制在一個(gè)固定的總時(shí)間以內(nèi)。默認(rèn)時(shí),沒有時(shí)間限制。
              -p postfile     File containing data to POST
              //包含了需要POST的數(shù)據(jù)的文件.
              -T content-type Content-type header for POSTing
              //POST數(shù)據(jù)所使用的Content-type頭信息。
              -v verbosity    How much troubleshooting info to print
              //設(shè)置顯示信息的詳細(xì)程度 - 4或更大值會(huì)顯示頭信息, 3或更大值可以顯示響應(yīng)代碼(404, 200等), 2或更大值可以顯示警告和其他信息。 -V 顯示版本號(hào)并退出。
              -w              Print out results in HTML tables
              //以HTML表的格式輸出結(jié)果。默認(rèn)時(shí),它是白色背景的兩列寬度的一張表。
              -i              Use HEAD instead of GET
             // 執(zhí)行HEAD請(qǐng)求,而不是GET。
              -x attributes   String to insert as table attributes
              //
              -y attributes   String to insert as tr attributes
              //
              -z attributes   String to insert as td or th attributes
              //
              -C attribute    Add cookie, eg. 'Apache=1234. (repeatable)
              //-C cookie-name=value 對(duì)請(qǐng)求附加一個(gè)Cookie:行。其典型形式是name=value的一個(gè)參數(shù)對(duì)。此參數(shù)可以重復(fù)。
              -H attribute    Add Arbitrary header line, eg. 'Accept-Encoding: gzip'
                              Inserted after all normal header lines. (repeatable)
              -A attribute    Add Basic WWW Authentication, the attributes
                              are a colon separated username and password.
              -P attribute    Add Basic Proxy Authentication, the attributes
                              are a colon separated username and password.
              //-P proxy-auth-username:password 對(duì)一個(gè)中轉(zhuǎn)代理提供BASIC認(rèn)證信任。用戶名和密碼由一個(gè):隔開,并以base64編碼形式發(fā)送。無論服務(wù)器是否需要(即, 是否發(fā)送了401認(rèn)證需求代碼),此字符串都會(huì)被發(fā)送。
              -X proxy:port   Proxyserver and port number to use
              -V              Print version number and exit
              -k              Use HTTP KeepAlive feature
              -d              Do not show percentiles served table.
              -S              Do not show confidence estimators and warnings.
              -g filename     Output collected data to gnuplot format file.
              -e filename     Output CSV file with percentages served
              -h              Display usage information (this message)
              //-attributes 設(shè)置 屬性的字符串. 缺陷程序中有各種靜態(tài)聲明的固定長度的緩沖區(qū)。另外,對(duì)命令行參數(shù)、服務(wù)器的響應(yīng)頭和其他外部輸入的解析也很簡單,這可能會(huì)有不良后果。它沒有完整地實(shí)現(xiàn)HTTP/1.x; 僅接受某些'預(yù)想'的響應(yīng)格式。 strstr(3)的頻繁使用可能會(huì)帶來性能問題,即, 你可能是在測試ab而不是服務(wù)器的性能。

          參數(shù)很多,一般我們用 -c 和 -n 參數(shù)就可以了. 例如:

          ./ab -c 1000 -n 1000 http://10.88.15.77/test.php

          這個(gè)表示同時(shí)處理1000個(gè)請(qǐng)求并運(yùn)行1000次index.php文件.
          #ab -c 1000 -n 1000 http://10.88.15.77/test.php


          Benchmarking 10.88.15.77 (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
          Completed 900 requests
          Finished 1000 requests


          Server Software:        Apache/2.2.8
          //平臺(tái)apache 版本2.2.8
          Server Hostname:        10.88.15.77
          //服務(wù)器主機(jī)名
          Server Port:            80
          //服務(wù)器端口

          Document Path:          /test.php

          //測試的頁面文檔
          Document Length:        1018 bytes
          //文檔大小

          Concurrency Level:      1000
          //并發(fā)數(shù)
          Time taken for tests:   8.188731 seconds
          //整個(gè)測試持續(xù)的時(shí)間
          Complete requests:      1000
          //完成的請(qǐng)求數(shù)量
          Failed requests:        0
          //失敗的請(qǐng)求數(shù)量
          Write errors:           0

          Total transferred:      1361581 bytes
          //整個(gè)場景中的網(wǎng)絡(luò)傳輸量
          HTML transferred:       1055666 bytes
          //整個(gè)場景中的HTML內(nèi)容傳輸量
          Requests per second:    122.12 [#/sec] (mean)
          //大家最關(guān)心的指標(biāo)之一,相當(dāng)于 LR 中的 每秒事務(wù)數(shù) ,后面括號(hào)中的 mean 表示這是一個(gè)平均值
          Time per request:       8188.731 [ms] (mean)
          //大家最關(guān)心的指標(biāo)之二,相當(dāng)于 LR 中的 平均事務(wù)響應(yīng)時(shí)間 ,后面括號(hào)中的 mean 表示這是一個(gè)平均值
          Time per request:       8.189 [ms] (mean, across all concurrent requests)
          //每個(gè)請(qǐng)求實(shí)際運(yùn)行時(shí)間的平均值
          Transfer rate:          162.30 [Kbytes/sec] received
          //平均每秒網(wǎng)絡(luò)上的流量,可以幫助排除是否存在網(wǎng)絡(luò)流量過大導(dǎo)致響應(yīng)時(shí)間延長的問題

          Connection Times (ms)
                        min mean[+/-sd] median   max
          Connect:        4 646 1078.7     89    3291
          Processing:   165 992 493.1    938    4712
          Waiting:      118 934 480.6    882    4554
          Total:        813 1638 1338.9   1093    7785
          //網(wǎng)絡(luò)上消耗的時(shí)間的分解,各項(xiàng)數(shù)據(jù)的具體算法還不是很清楚

          Percentage of the requests served within a certain time (ms)
          50%   1093
          66%   1247
          75%   1373
          80%   1493
          90%   4061
          95%   4398
          98%   5608
          99%   7368
          100%   7785 (longest request)
          //整個(gè)場景中所有請(qǐng)求的響應(yīng)情況。在場景中每個(gè)請(qǐng)求都有一個(gè)響應(yīng)時(shí)間,其中50%的用戶響應(yīng)時(shí)間小于1093 毫秒,60% 的用戶響應(yīng)時(shí)間小于1247 毫秒,最大的響應(yīng)時(shí)間小于7785 毫秒

                由于對(duì)于并發(fā)請(qǐng)求,cpu實(shí)際上并不是同時(shí)處理的,而是按照每個(gè)請(qǐng)求獲得的時(shí)間片逐個(gè)輪轉(zhuǎn)處理的,所以基本上第一個(gè)Time per request時(shí)間約等于第二個(gè)Time per request時(shí)間乘以并發(fā)請(qǐng)求數(shù)
          轉(zhuǎn)自:http://blog.sina.com.cn/s/blog_3c9872d00100dbox.html

          主站蜘蛛池模板: 修水县| 霍州市| 沧州市| 绩溪县| 清水河县| 酒泉市| 彰武县| 双牌县| 庆城县| 保德县| 浠水县| 吴旗县| 双江| 绥芬河市| 神农架林区| 精河县| 庆云县| 深圳市| 墨脱县| 图木舒克市| 红桥区| 千阳县| 田东县| 肥城市| 长治市| 甘洛县| 射阳县| 武山县| 楚雄市| 繁昌县| 湖州市| 宜川县| 大石桥市| 左贡县| 临江市| 永州市| 阜康市| 阿巴嘎旗| 西华县| 边坝县| 南投市|