青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

C++的天空

常用鏈接

統計

最新評論

2008年3月28日 #

TCP收包小結

先說說TCP收包的context(不定長包)。一般情況,發送方發送一個包,然后接收方收到一個包,這是最好處理的。第二種情況,當每次發生的包比較小時,發送數據時,TCP會啟用優化算法,將多個小包集中起來發送,以提高傳輸效率。此時接收方的recv buffer中,可能出現不止一個包。第三種情況,recv buffer中每次只一個包,但接收方沒及時取包,這時recv buffer中會積累多個包。
理所當然,TCP收包要考慮所有這些情況。一般來說有三種方法。第一種,定義好通訊協議,先收包頭,然后根據包頭中的消息真實大小,接收消息剩余部分。第二種方法,通訊協議規定好每個消息的開始和結束標識符。然后每次recv得到的數據先放到一個大(比如你的最大packet的2倍)buffer中,最后再來分析這個buffer分包。第三種方法,先用recv+MSG_PEEK接收某個固定長度,然后對接收到的"包"進行分析,然后做真正的recv操作。

posted @ 2008-03-28 11:28 ecopgm 閱讀(1141) | 評論 (0)編輯 收藏

2008年3月24日 #

高并發和高負載

能不能接受爆發連接(并發度如何),主要是取決于accept的速度。一個TCP連接的建立,要在client和server之間,完成三次握手,然后連接會被放到完成隊列中,accept從完成隊列中取出連接并返回。任何影響accept取連接的因素,都會影響并發度。一般策略是,1 獨立處理accept,2 使用epoll處理accept,這兩種情況,并發度都是不錯的。
并發地接受了這么多連接,并不代表能完全處理。假如有很多連接同時在線,server accept成功并收到了數據,這時消息被放到消息隊列中,等待邏輯線程來處理。因為生產者(收數據)的速度總是大于消費者(處理數據)的速度,因此消息隊列會有考慮流控,以免系統資源被耗光。這樣,有些消息就可能丟失。這就是同時在線連接數的問題。
前者是高并發,后者是高負載。設計時會權衡偏向。

posted @ 2008-03-24 22:36 ecopgm 閱讀(1269) | 評論 (0)編輯 收藏

并發策略總結

并發服務器有三種常見的架構:
1. 單線程epoll(ET非阻塞I/O) +線程池,也叫半同步半異步模式。這種模型比較常見,而且因為異步層和同步層使用消息隊列傳遞消息,更容易實現對消息的FIFO處理。缺點就是線程的同步和上下文切換開銷比較大。
2. ConnectionPerThread+阻塞型I/O。這是最古老的服務器并發模型,不太適合現今的這些高并發高負載服務器,當連接數巨大的時候,創建銷毀線程的開銷會無法承受,并且內核創建線程的速度也會成為瓶頸。這種模型的一種改進型就是領導者/跟隨者模式,它吸取第一種模型中,線程數量不會膨脹的優點,使用線程池來處理連接。每當有連接到達時,都使用一個線程阻塞處理,處理完成后,線程再回到線程池中,這樣有限的線程模擬出了ConnectionPerThread。一般來說,領導者/跟隨者模型比第一種模型更加高效,因為它減少了線程同步和切換的開銷,它的缺點就是FIFO很難保證。
3. 流水線模型。前面兩種模式都有個缺點,它們不能花太長時間處理邏輯,因為在多CPU系統上,某些耗時的長請求可能會不斷占住CPU,而導致短請求得不到處理,這會使某些CPU閑置。于是這種模型提出,將請求處理的過程劃分步驟,不同的步驟考慮不同的資源處理(比如CPU, DISK I/O等),每個步驟使用單獨的線程或線程池。這樣比較耗時的操作可能集中在流水線的下級,而短請求也可以在上級得到快速處理。因為各級線程之間使用消息隊列傳遞請求,也很容易實現FIFO。

posted @ 2008-03-24 14:43 ecopgm 閱讀(723) | 評論 (0)編輯 收藏

I/O策略小結

如何高效處理多個socket I/O的讀寫,是提高服務器性能的重點問題。unix-like下面,現有機制有select,poll,  epoll,kqueue,/dev/poll兩大類。

Select有個缺點,它用fd_set管理所有要監視的I/O句柄,但是fd_set是一個位數組,只能接受句柄號小于FD_SETSIZE(默認1024)的句柄,雖然進程默認句柄號都是小于1024的,但是可以通過ulimit –n來修改,尤其是連接數超過1024時必需這么做(實際可能更少),如果要將大于1024的句柄放入fd_set,就可能發生數組越界程序崩潰的場面。

Poll雖然解決了FD_SETSIZE問題,但是它和select一樣,都有性能上的瓶頸。它們都會隨著連接數的增加性能直線下降。這主要有兩個原因,其一是每次select/poll操作,kernel都會建立一個當前線程關心的事件列表,并讓線程阻塞在這個列表上,這是很耗時的操作。其二是每次select/poll返回后,線程都要掃描所有句柄來dispatch已發生的事件,這也是很耗時的。當連接數巨大時,這種消耗積累起來,就很受不了。

為了解決select/poll的性能問題,unix-like系統上開發出了三套新的利器epollkqueue/dev/poll,其中epolllinux的,kqueuefreebsd的,/dev/pollSolaris上的,它們是select/poll的替代品。它們的設計就是針對select/poll的性能問題,主要避免 1。每次調用都建立事件等待列表,取而代之建立長期的事件關注列表,這個列表可通過句柄(比如epfd)來增加和刪除事件。2。調用返回之后,不再需要遍歷所有句柄進行分發,內核會直接返回當前已發生的事件。不用說,性能在select, poll基礎上有了大幅提升。

要注意的是,凡是使用readiness notification(LT)或者readiness change notification(ET)機制,都應該配合非阻塞I/O,因為這種事件通知,并不一定表示文件描述符真正就緒,如果收到通知之后去read,很有可能進入阻塞狀態,這會嚴重影響服務器的并發性能,同時對ET模式,不能漏掉任何事件的處理,并且每次都應該讀到socket返回EWOULDBLOCK為止,不然這個socket之后會永遠保持沉默。

posted @ 2008-03-24 14:40 ecopgm 閱讀(684) | 評論 (0)編輯 收藏

僅列出標題  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            黑人一区二区三区四区五区| 亚洲午夜久久久久久尤物| 亚洲国产一区二区在线| 亚洲高清视频在线| 亚洲精选91| 99天天综合性| 亚洲欧美日韩精品在线| 久久久999精品免费| 米奇777在线欧美播放| 久久综合给合| 亚洲精品乱码视频| 一区二区不卡在线视频 午夜欧美不卡在 | 久久综合色8888| 欧美精品日本| 国产偷国产偷亚洲高清97cao | 激情五月婷婷综合| 99精品国产在热久久下载| 亚洲欧美日韩国产| 麻豆精品传媒视频| 亚洲人线精品午夜| 欧美偷拍一区二区| 国产亚洲亚洲| 一区二区三区 在线观看视频| 欧美一区二区成人| 亚洲国产成人高清精品| 亚洲私拍自拍| 蜜桃av噜噜一区二区三区| 国产精品久久久久久久久久久久| 一区二区三区在线观看视频| 一区二区三区免费看| 久久综合九九| 亚洲欧美激情四射在线日| 欧美成人福利视频| 韩日精品中文字幕| 欧美一二三区在线观看| 亚洲黄色成人| 久久综合99re88久久爱| 国产美女扒开尿口久久久| 亚洲精品中文字幕有码专区| 久久免费国产| 香蕉久久一区二区不卡无毒影院| 欧美精品日韩精品| 亚洲全黄一级网站| 欧美激情小视频| 久久九九电影| 合欧美一区二区三区| 欧美在线视频a| 亚洲图片在区色| 国产精品成人在线| 亚洲婷婷国产精品电影人久久| 欧美激情在线| 欧美成人国产| 亚洲精品一区二区三区99| 欧美成人综合一区| 久久婷婷久久| 亚洲电影免费观看高清| 免费成人你懂的| 久久青青草综合| 在线免费观看日韩欧美| 免费成人你懂的| 老司机午夜精品视频在线观看| 狠狠爱成人网| 老鸭窝91久久精品色噜噜导演| 欧美中在线观看| 影音先锋亚洲视频| 欧美高清hd18日本| 欧美激情在线有限公司| 亚洲精品日韩在线观看| 亚洲剧情一区二区| 国产精品成人免费视频 | 18成人免费观看视频| 蜜桃精品一区二区三区| 老司机午夜精品视频在线观看| 亚洲电影下载| 亚洲精品国久久99热| 国产精品美女诱惑| 久久亚洲免费| 免费欧美日韩国产三级电影| 欧美激情国产日韩| 欧美理论在线| 欧美一级视频| 欧美1区2区3区| 亚洲午夜精品17c| 欧美一区在线看| 亚洲免费观看高清完整版在线观看熊| 亚洲精品国产精品久久清纯直播 | 久久国产日韩| 亚洲精品视频在线观看免费| 99精品免费| 伊人久久久大香线蕉综合直播| 欧美激情精品久久久久久黑人| 欧美日韩国产综合视频在线观看 | aa亚洲婷婷| 欧美一级免费视频| 日韩视频中文| 欧美一级视频免费在线观看| 亚洲国产影院| 亚洲欧美精品suv| 亚洲精品国精品久久99热一| 亚洲男人的天堂在线| 亚洲精品网站在线播放gif| 亚洲综合大片69999| 亚洲精品乱码久久久久久日本蜜臀| 亚洲视频在线观看视频| 亚洲欧洲免费视频| 欧美在线首页| 亚洲性视频网站| 欧美 日韩 国产在线| 久久精品国产综合精品| 欧美日韩一区在线播放| 欧美成人午夜激情视频| 国产美女精品免费电影| 99精品视频免费| 亚洲精品少妇网址| 美女脱光内衣内裤视频久久影院| 欧美一区二区三区播放老司机 | 欧美激情乱人伦| 国产亚洲亚洲| 午夜一级在线看亚洲| 亚洲自拍三区| 欧美日韩激情小视频| 狂野欧美激情性xxxx| 国产欧美日韩亚洲一区二区三区| 亚洲乱码久久| 夜夜嗨av一区二区三区免费区| 久久在精品线影院精品国产| 久久天天综合| 在线观看欧美激情| 久久久久久成人| 久久久在线视频| 国产一区二区电影在线观看| 午夜精品久久久久久久蜜桃app | 欧美一级在线视频| 国产精品久久久久久久久免费| 日韩视频精品在线观看| 国产精品久久久久9999吃药| 亚洲欧美国产精品专区久久| 欧美三级电影一区| 日韩一级大片| 亚洲欧美成人网| 欧美三级乱人伦电影| 夜夜爽夜夜爽精品视频| 一区二区三区国产精品| 欧美午夜在线| 午夜欧美精品| 老司机午夜精品视频| 亚洲第一网站| 欧美激情视频网站| 99天天综合性| 欧美中文字幕久久| 一区二区亚洲精品| 欧美激情精品久久久久久大尺度 | 香港久久久电影| 国产一区二区三区久久| 葵司免费一区二区三区四区五区| 欧美黄色一区二区| 夜夜爽www精品| 国产麻豆精品theporn| 欧美在线播放一区| 亚洲国产第一| 亚洲欧美日韩爽爽影院| 狠狠色狠狠色综合日日tαg| 免播放器亚洲一区| 亚洲午夜电影网| 老司机免费视频一区二区| 亚洲精品一区中文| 国产精品尤物福利片在线观看| 久久av一区二区三区漫画| 亚洲韩日在线| 久久成人资源| 日韩一级免费| 国内精品久久久久影院色| 欧美精品日韩综合在线| 欧美一区不卡| 亚洲欧洲精品一区二区三区不卡| 午夜在线a亚洲v天堂网2018| 亚洲成色最大综合在线| 国产精品久久久一区二区三区| 久久国产高清| 一区二区免费在线播放| 免费亚洲婷婷| 久久超碰97中文字幕| 99视频在线观看一区三区| 国产主播一区二区| 欧美午夜不卡在线观看免费 | 国产日韩欧美自拍| 欧美黄色成人网| 久久久综合激的五月天| 亚洲图片欧洲图片av| 亚洲精品久久久蜜桃| 久久免费少妇高潮久久精品99| 这里只有精品丝袜| 亚洲精品在线免费| 亚洲成人在线| 黑人操亚洲美女惩罚| 国产日韩1区| 国产精品网曝门| 国产精品www网站| 欧美国产综合| 你懂的网址国产 欧美|