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

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

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

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

    2008年9月19日

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

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

    理論

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

    實(shí)踐

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

    擴(kuò)展內(nèi)容

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

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

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

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

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

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

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

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

    結(jié)論

    無論是對(duì)于服務(wù)器還是客戶端, 認(rèn)為”一臺(tái)機(jī)器最多建立65536個(gè)TCP連接”是沒有根據(jù)的, 理論上遠(yuǎn)遠(yuǎn)超過這個(gè)值.

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

    一、http_load

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

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

    具,它可以以一個(gè)單一的進(jìn)程運(yùn)行,一般不會(huì)把客戶機(jī)搞死。還可以測(cè)試HTTPS類的網(wǎng)站請(qǐ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ā)訪問進(jìn)程數(shù)  -s 訪問時(shí)間  需要訪問的URL文件

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

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

    準(zhǔn)備URL文件:urllist.txt,文件格式是每行一個(gè)URL,URL最好超過50-100個(gè)測(cè)試效果比較好.文件格式

    如下:
    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ù)了解了,我們來看運(yùn)行一條命令來看看它的返回結(jié)果
    命令:% ./http_load -rate 5 -seconds 10 urls說明執(zhí)行了一個(gè)持續(xù)時(shí)間10秒的測(cè)試,每秒的頻率為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
    說明在上面的測(cè)試中運(yùn)行了49個(gè)請(qǐng)求,最大的并發(fā)進(jìn)程數(shù)是2,總計(jì)傳輸?shù)臄?shù)據(jù)是289884bytes,運(yùn)行的時(shí)間是10.0148秒
    2.5916 mean bytes/connection說明每一連接平均傳輸?shù)臄?shù)據(jù)量289884/49=5916
    3.4.89274 fetches/sec, 28945.5 bytes/sec
    說明每秒的響應(yīng)請(qǐng)求為4.89274,每秒傳遞的數(shù)據(jù)為28945.5 bytes/sec
    4.msecs/connect: 28.8932 mean, 44.243 max, 24.488 min說明每連接的平均響應(yīng)時(shí)間是28.8932 msecs

    ,最大的響應(yīng)時(shí)間44.243 msecs,最小的響應(yīng)時(shí)間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)遇到了瓶頸。
    特殊說明:
    測(cè)試結(jié)果中主要的指標(biāo)是 fetches/sec、msecs/connect 這個(gè)選項(xiàng),即服務(wù)器每秒能夠響應(yīng)的查詢次數(shù),

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

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

     

    二、webbench

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

    用法:

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

    三、ab
    ab是apache自帶的一款功能強(qiáng)大的測(cè)試工具
    安裝了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

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

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

    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 //總共用時(shí)
    Data transferred: 84273.91 MB //共數(shù)據(jù)傳輸84273.91 MB
    Response time: 0.37 secs //相應(yīng)用時(shí)1.65秒:顯示網(wǎng)絡(luò)連接的速度
    Transaction rate: 569.91 trans/sec //均每秒完成 569.91 次處理:表示服務(wù)器后
    Throughput: 14.05 MB/sec //平均每秒傳送數(shù)據(jù)
    Concurrency: 213.42 //實(shí)際最高并發(fā)數(shù)
    Successful transactions: 2564081 //成功處理次數(shù)
    Failed transactions: 11 //失敗處理次數(shù)
    Longest transaction: 29.04 //每次傳輸所花最長時(shí)間
    Shortest transaction: 0.00 //每次傳輸所花最短時(shí)間

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

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

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

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

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

         摘要: hibernate的hibernate.hbm2ddl.auto屬性  閱讀全文

    posted @ 2008-09-19 18:10 陜西BOY 閱讀(8034) | 評(píng)論 (2)編輯 收藏


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

    Copyright © 陜西BOY

    主站蜘蛛池模板: 免费无码毛片一区二区APP| 亚洲欧美自偷自拍另类视| 国产精品亚洲lv粉色| 91成年人免费视频| 国产精品亚洲аv无码播放| 99亚洲精品卡2卡三卡4卡2卡| **aaaaa毛片免费| 无码乱人伦一区二区亚洲一| 不卡视频免费在线观看| 亚洲国产小视频精品久久久三级| 亚洲av永久中文无码精品| 99在线视频免费观看视频| 亚洲国产精品成人综合久久久| 特色特黄a毛片高清免费观看| 免费观看一级毛片| 亚洲Aⅴ在线无码播放毛片一线天 亚洲avav天堂av在线网毛片 | 久久亚洲日韩精品一区二区三区 | 久久亚洲国产成人精品无码区| 国产成人亚洲精品播放器下载| 精品少妇人妻AV免费久久洗澡| 亚洲精品无码中文久久字幕| 国产无遮挡又黄又爽免费视频| 亚洲国产精华液2020| 无码视频免费一区二三区 | 亚洲A∨午夜成人片精品网站| 亚洲欧美国产国产一区二区三区| 欧洲黑大粗无码免费| 亚洲看片无码在线视频| 天天操夜夜操免费视频| 亚洲欧美第一成人网站7777| 麻豆精品国产免费观看| 亚洲乱码卡一卡二卡三| 99国产精品永久免费视频 | 国产精品亚洲A∨天堂不卡| 国产免费一区二区三区不卡| 亚洲精品国产精品乱码不卡| 色偷偷女男人的天堂亚洲网 | 亚洲美女免费视频| 亚洲熟妇无码八V在线播放| 免费观看男人免费桶女人视频| 99热亚洲色精品国产88|