<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    歡迎光臨郝學(xué)武的blog。

    2008年12月8日

    因為TCP端口號是16位無符號整數(shù), 最大65535, 所以一臺服務(wù)器最多支持65536個TCP socket連接.” – 一個非常經(jīng)典的誤解! 即使是有多年網(wǎng)絡(luò)編程經(jīng)驗的人, 也會持有這個錯誤結(jié)論.

    要戳破這個錯誤結(jié)論, 可以從理論和實踐兩方面來.

    理論

    系統(tǒng)通過一個四元組來唯一標識一條TCP連接. 這個四元組的結(jié)構(gòu)是{local ip, local port, remote ip, remote port}, 對于IPv4, 系統(tǒng)理論上最多可以管理2^(32+16+32+16), 2的96次方個連接. 如果不僅僅考慮TCP, 則是一個五元組, 加上協(xié)議號(TCP, UDP或者其它).

    實踐

    服務(wù)器綁定一個ip:port, 然后accept連接, 所有accept的連接使用的本地地址也是同樣的ip:port.

    擴展內(nèi)容

    如果某個客戶端向同一個TCP端點(ip:port)發(fā)起主動連接, 那么每一條連接都必須使用不同的本地TCP端點, 如果客戶端只有一個IP則是使用不同的本地端口, 該端口的范圍在*nix系統(tǒng)上的一個例子是32768到61000, 可以通過如下命令查看:

    [root@benegg.com ~]# cat /proc/sys/net/ipv4/ip_local_port_range 32768   61000 

    也就是說, 一個客戶端連接同一個服務(wù)器(比如進行壓力測試), 最多可以發(fā)起30000個左右的連接.

    TCP客戶端(TCP的主動發(fā)起者)可以在同一ip:port上向不同的服務(wù)器發(fā)起主動連接, 只需在bind之前對socket設(shè)置SO_REUSEADDR選項.

    系統(tǒng)支持的最大打開文件描述符數(shù)(包括socket連接):

    [root@benegg.com ~]# cat /proc/sys/fs/file-max 580382 

    單個進程所能打開的最大文件描述符數(shù):

    [root@benegg.com ~]# ulimit -n 1024 

    結(jié)論

    無論是對于服務(wù)器還是客戶端, 認為”一臺機器最多建立65536個TCP連接”是沒有根據(jù)的, 理論上遠遠超過這個值.

    posted @ 2013-12-17 14:10 陜西BOY 閱讀(385) | 評論 (0)編輯 收藏

    一、http_load

    程序非常小,解壓后也不到100K

    http_load以并行復(fù)用的方式運行,用以測試web服務(wù)器的吞吐量與負載。但是它不同于大多數(shù)壓力測試工

    具,它可以以一個單一的進程運行,一般不會把客戶機搞死。還可以測試HTTPS類的網(wǎng)站請求。

    下載地址:http://soft.vpser.net/test/http_load/http_load-12mar2006.tar.gz
    安裝很簡單
    #tar zxvf http_load-12mar2006.tar.gz
    #cd http_load-12mar2006
    #make && make install

    命令格式:http_load  -p 并發(fā)訪問進程數(shù)  -s 訪問時間  需要訪問的URL文件

    參數(shù)其實可以自由組合,參數(shù)之間的選擇并沒有什么限制。比如你寫成http_load -parallel 5 -seconds

    300 urls.txt也是可以的。我們把參數(shù)給大家簡單說明一下。
    -parallel 簡寫-p :含義是并發(fā)的用戶進程數(shù)。
    -fetches 簡寫-f :含義是總計的訪問次數(shù)
    -rate    簡寫-p :含義是每秒的訪問頻率
    -seconds簡寫-s :含義是總計的訪問時間

    準備URL文件:urllist.txt,文件格式是每行一個URL,URL最好超過50-100個測試效果比較好.文件格式

    如下:
    http://www.vpser.net/uncategorized/choose-vps.html
    http://www.vpser.net/vps-cp/hypervm-tutorial.html
    http://www.vpser.net/coupons/diavps-april-coupons.html
    http://www.vpser.net/security/vps-backup-web-mysql.html
    例如:

    http_load -p 30 -s 60  urllist.txt
    參數(shù)了解了,我們來看運行一條命令來看看它的返回結(jié)果
    命令:% ./http_load -rate 5 -seconds 10 urls說明執(zhí)行了一個持續(xù)時間10秒的測試,每秒的頻率為5。

    49 fetches, 2 max parallel, 289884 bytes, in 10.0148 seconds5916 mean bytes/connection4.89274

    fetches/sec, 28945.5 bytes/secmsecs/connect: 28.8932 mean, 44.243 max, 24.488 minmsecs/first

    -response: 63.5362 mean, 81.624 max, 57.803 minHTTP response codes: code 200 — 49 

    結(jié)果分析:
    1.49 fetches, 2 max parallel, 289884 bytes, in 10.0148 seconds
    說明在上面的測試中運行了49個請求,最大的并發(fā)進程數(shù)是2,總計傳輸?shù)臄?shù)據(jù)是289884bytes,運行的時間是10.0148秒
    2.5916 mean bytes/connection說明每一連接平均傳輸?shù)臄?shù)據(jù)量289884/49=5916
    3.4.89274 fetches/sec, 28945.5 bytes/sec
    說明每秒的響應(yīng)請求為4.89274,每秒傳遞的數(shù)據(jù)為28945.5 bytes/sec
    4.msecs/connect: 28.8932 mean, 44.243 max, 24.488 min說明每連接的平均響應(yīng)時間是28.8932 msecs

    ,最大的響應(yīng)時間44.243 msecs,最小的響應(yīng)時間24.488 msecs
    5.msecs/first-response: 63.5362 mean, 81.624 max, 57.803 min
    6、HTTP response codes: code 200 — 49     說明打開響應(yīng)頁面的類型,如果403的類型過多,那可能

    要注意是否系統(tǒng)遇到了瓶頸。
    特殊說明:
    測試結(jié)果中主要的指標是 fetches/sec、msecs/connect 這個選項,即服務(wù)器每秒能夠響應(yīng)的查詢次數(shù),

    用這個指標來衡量性能。似乎比 apache的ab準確率要高一些,也更有說服力一些。
    Qpt-每秒響應(yīng)用戶數(shù)和response time,每連接響應(yīng)用戶時間。
    測試的結(jié)果主要也是看這兩個值。當(dāng)然僅有這兩個指標并不能完成對性能的分析,我們還需要對服務(wù)器的

    cpu、men進行分析,才能得出結(jié)論

     

    二、webbench

    webbench是Linux下的一個網(wǎng)站壓力測試工具,最多可以模擬3萬個并發(fā)連接去測試網(wǎng)站的負載能力。下載地址可以到google搜,我這里給出一個
    下載地址:http://soft.vpser.net/test/webbench/webbench-1.5.tar.gz
    這個程序更小,解壓后不到50K,呵呵
    安裝非常簡單
    #tar zxvf webbench-1.5.tar.gz
    #cd webbench-1.5
    #make && make install
    會在當(dāng)前目錄生成webbench可執(zhí)行文件,直接可以使用了

    用法:

    webbench -c 并發(fā)數(shù) -t 運行測試時間 URL
    如:
    webbench -c 5000 -t 120 http://www.vpser.net

    三、ab
    ab是apache自帶的一款功能強大的測試工具
    安裝了apache一般就自帶了,
    用法可以查看它的說明

    $ ./ab
    ./ab: wrong number of arguments
    Usage: ./ab [options] [http://]hostname[:port]/path
    Options are:
    -n requests Number of requests to perform
    -c concurrency Number of multiple requests to make
    -t timelimit Seconds to max. wait for responses
    -p postfile File containing data to POST
    -T content-type Content-type header for POSTing
    -v verbosity How much troubleshooting info to print
    -w Print out results in HTML tables
    -i Use HEAD instead of 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)
    -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.
    -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)
    參數(shù)眾多,一般我們用到的是-n 和-c
    例如:
    ./ab -c 1000 -n 100 http://www.vpser.net/index.php

    這個表示同時處理1000個請求并運行100次index.php文件.
    四、Siege
    一款開源的壓力測試工具,可以根據(jù)配置對一個WEB站點進行多用戶的并發(fā)訪問,記錄每個用戶所有請求過程的相應(yīng)時間,并在一定數(shù)量的并發(fā)訪問下重復(fù)進行。
    官方:http://www.joedog.org/
    Siege下載:http://soft.vpser.net/test/siege/siege-2.67.tar.gz
    解壓:
    # tar -zxf siege-2.67.tar.gz
    進入解壓目錄:
    # cd siege-2.67/
    安裝:
    #./configure ; make
    #make install

    使用
    siege -c 200 -r 10 -f example.url
    -c是并發(fā)量,-r是重復(fù)次數(shù)。 url文件就是一個文本,每行都是一個url,它會從里面隨機訪問的。

    example.url內(nèi)容:

    http://www.licess.cn
    http://www.vpser.net
    http://soft.vpser.net

    結(jié)果說明
    Lifting the server siege… done.
    Transactions: 3419263 hits //完成419263次處理
    Availability: 100.00 % //100.00 % 成功率
    Elapsed time: 5999.69 secs //總共用時
    Data transferred: 84273.91 MB //共數(shù)據(jù)傳輸84273.91 MB
    Response time: 0.37 secs //相應(yīng)用時1.65秒:顯示網(wǎng)絡(luò)連接的速度
    Transaction rate: 569.91 trans/sec //均每秒完成 569.91 次處理:表示服務(wù)器后
    Throughput: 14.05 MB/sec //平均每秒傳送數(shù)據(jù)
    Concurrency: 213.42 //實際最高并發(fā)數(shù)
    Successful transactions: 2564081 //成功處理次數(shù)
    Failed transactions: 11 //失敗處理次數(shù)
    Longest transaction: 29.04 //每次傳輸所花最長時間
    Shortest transaction: 0.00 //每次傳輸所花最短時間

    posted @ 2011-11-11 15:33 陜西BOY 閱讀(647) | 評論 (0)編輯 收藏

         摘要: spring事務(wù)管理
      閱讀全文

    posted @ 2011-05-16 11:01 陜西BOY 閱讀(2041) | 評論 (3)編輯 收藏

         摘要: hibernate主鍵常用方式  閱讀全文

    posted @ 2008-12-08 23:26 陜西BOY 閱讀(1720) | 評論 (1)編輯 收藏


    posts - 17, comments - 65, trackbacks - 0, articles - 28

    Copyright © 陜西BOY

    主站蜘蛛池模板: 亚洲va无码手机在线电影| 最近2019中文免费字幕| 热久久这里是精品6免费观看| 午夜在线亚洲男人午在线| 亚洲AV电影天堂男人的天堂| 亚洲精品无码久久久久YW| 亚洲熟妇AV乱码在线观看| 亚洲人成网站999久久久综合| 亚洲码和欧洲码一码二码三码| 亚洲国产欧洲综合997久久| 亚洲国产精品嫩草影院| 亚洲变态另类一区二区三区| 国产av无码专区亚洲av毛片搜| 免费无码婬片aaa直播表情| 又硬又粗又长又爽免费看| 91免费福利视频| 久热免费在线视频| 精品国产sm捆绑最大网免费站| 99久久国产热无码精品免费 | 亚洲一区二区三区高清在线观看| 亚洲人成图片网站| 色五月五月丁香亚洲综合网| 视频免费1区二区三区| 免费人成激情视频在线观看冫| 99在线观看免费视频| 四虎永久在线精品免费网址| 拔擦拔擦8x华人免费久久| 亚洲人成电影网站国产精品| 亚洲爆乳精品无码一区二区三区| 精品亚洲成a人片在线观看少妇| 色在线亚洲视频www| 黄色免费网址在线观看| 黄色免费在线网站| 欧美男同gv免费网站观看| 亚洲AV日韩精品一区二区三区 | 性生交片免费无码看人| 国产又粗又长又硬免费视频| 中文字幕亚洲无线码| 中文字幕亚洲色图| 亚洲欧美日韩国产成人| 中文字幕免费在线观看动作大片 |