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

C++的天空

常用鏈接

統(tǒng)計(jì)

最新評論

2008年3月28日 #

TCP收包小結(jié)

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

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

2008年3月24日 #

高并發(fā)和高負(fù)載

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

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

并發(fā)策略總結(jié)

并發(fā)服務(wù)器有三種常見的架構(gòu):
1. 單線程epoll(ET非阻塞I/O) +線程池,也叫半同步半異步模式。這種模型比較常見,而且因?yàn)楫惒綄雍屯綄邮褂孟㈥?duì)列傳遞消息,更容易實(shí)現(xiàn)對消息的FIFO處理。缺點(diǎn)就是線程的同步和上下文切換開銷比較大。
2. ConnectionPerThread+阻塞型I/O。這是最古老的服務(wù)器并發(fā)模型,不太適合現(xiàn)今的這些高并發(fā)高負(fù)載服務(wù)器,當(dāng)連接數(shù)巨大的時(shí)候,創(chuàng)建銷毀線程的開銷會無法承受,并且內(nèi)核創(chuàng)建線程的速度也會成為瓶頸。這種模型的一種改進(jìn)型就是領(lǐng)導(dǎo)者/跟隨者模式,它吸取第一種模型中,線程數(shù)量不會膨脹的優(yōu)點(diǎn),使用線程池來處理連接。每當(dāng)有連接到達(dá)時(shí),都使用一個(gè)線程阻塞處理,處理完成后,線程再回到線程池中,這樣有限的線程模擬出了ConnectionPerThread。一般來說,領(lǐng)導(dǎo)者/跟隨者模型比第一種模型更加高效,因?yàn)樗鼫p少了線程同步和切換的開銷,它的缺點(diǎn)就是FIFO很難保證。
3. 流水線模型。前面兩種模式都有個(gè)缺點(diǎn),它們不能花太長時(shí)間處理邏輯,因?yàn)樵诙郈PU系統(tǒng)上,某些耗時(shí)的長請求可能會不斷占住CPU,而導(dǎo)致短請求得不到處理,這會使某些CPU閑置。于是這種模型提出,將請求處理的過程劃分步驟,不同的步驟考慮不同的資源處理(比如CPU, DISK I/O等),每個(gè)步驟使用單獨(dú)的線程或線程池。這樣比較耗時(shí)的操作可能集中在流水線的下級,而短請求也可以在上級得到快速處理。因?yàn)楦骷壘€程之間使用消息隊(duì)列傳遞請求,也很容易實(shí)現(xiàn)FIFO。

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

I/O策略小結(jié)

如何高效處理多個(gè)socket I/O的讀寫,是提高服務(wù)器性能的重點(diǎn)問題。unix-like下面,現(xiàn)有機(jī)制有select,poll,  epoll,kqueue,/dev/poll兩大類。

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

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

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

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

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

僅列出標(biāo)題  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久精品人人做人人综合 | 欧美在线观看视频一区二区| 国产精品成av人在线视午夜片| 一本久久a久久免费精品不卡| 亚洲高清视频的网址| 性欧美大战久久久久久久久| 亚洲欧洲另类| 99成人在线| 国产美女一区二区| 久久亚洲不卡| 欧美成人精品在线视频| 亚洲一区二区三区高清| 亚洲欧美久久久| 最新日韩欧美| 亚洲视频播放| 亚洲丰满少妇videoshd| 99精品久久久| 国内揄拍国内精品久久| 91久久久久久国产精品| 国产久一道中文一区| 美女脱光内衣内裤视频久久影院 | 亚洲国产欧美国产综合一区| 欧美色视频在线| 久久久www成人免费无遮挡大片 | 91久久精品日日躁夜夜躁国产| 欧美性猛交xxxx乱大交蜜桃| 久久久国产精品一区| 欧美国产日本| 久久精彩视频| 欧美日韩一区二区三区免费看| 性欧美xxxx视频在线观看| 男人插女人欧美| 欧美一级专区免费大片| 免费永久网站黄欧美| 久久国产精品黑丝| 欧美精品粉嫩高潮一区二区| 久久精品中文| 国产精品白丝jk黑袜喷水| 亚洲大黄网站| 国产一区二区看久久| 日韩视频―中文字幕| 亚洲第一精品福利| 羞羞答答国产精品www一本| 一本大道久久a久久精品综合| 久久精品国产2020观看福利| 午夜久久tv| 欧美日韩一区精品| 亚洲国产成人精品女人久久久| 国产小视频国产精品| 在线午夜精品自拍| 亚洲免费av片| 麻豆精品网站| 欧美激情视频一区二区三区在线播放| 国产日韩一区在线| 亚洲一区二区免费看| 亚洲欧美日韩精品综合在线观看| 欧美久久久久久| 亚洲日本理论电影| 99精品国产在热久久婷婷| 麻豆精品视频在线| 欧美激情一二区| 亚洲电影av在线| 欧美88av| 欧美成人国产va精品日本一级| 精品1区2区| 久久综合999| 欧美视频二区| 亚洲日产国产精品| 在线欧美电影| 欧美激情精品久久久久久黑人| 欧美成人黄色小视频| 亚洲黄色毛片| 欧美精品一区二区三区在线播放 | 午夜欧美视频| 国产日韩在线播放| 久久精品国产亚洲aⅴ| 裸体歌舞表演一区二区 | 久久综合伊人77777尤物| 欧美顶级少妇做爰| 91久久精品美女高潮| 欧美精品久久久久久久免费观看 | 亚洲精品美女91| 欧美区二区三区| 亚洲亚洲精品在线观看| 久久大香伊蕉在人线观看热2| 狠狠色狠狠色综合日日小说| 另类专区欧美制服同性| 日韩视频―中文字幕| 久久狠狠久久综合桃花| 亚洲福利视频专区| 欧美日韩综合| 久久精品一区蜜桃臀影院 | 在线性视频日韩欧美| 国产精品久久久久91| 久久久久99精品国产片| 亚洲精品久久久久久下一站| 小黄鸭精品aⅴ导航网站入口| 精品av久久707| 欧美日韩精品在线播放| 午夜在线一区二区| 91久久夜色精品国产九色| 欧美在线日韩精品| 亚洲精品影院在线观看| 国产性猛交xxxx免费看久久| 欧美成人一区二免费视频软件| 亚洲在线第一页| 亚洲欧洲精品一区| 久久精品最新地址| 亚洲午夜精品久久久久久浪潮| 韩国精品主播一区二区在线观看| 欧美日韩综合不卡| 久久综合色播五月| 亚洲欧美日本另类| 亚洲精品久久久久中文字幕欢迎你 | 亚洲网友自拍| 欧美激情国产精品| 久久精品成人一区二区三区蜜臀| 亚洲精品国产精品久久清纯直播| 国产三区精品| 国产精品劲爆视频| 欧美片第1页综合| 免费在线成人| 久久精品国产第一区二区三区最新章节| 亚洲精品一区二区三区四区高清 | ●精品国产综合乱码久久久久| 欧美高清视频在线观看| 欧美亚洲一级| 中文久久精品| 99热精品在线| 亚洲精品三级| 亚洲日本va午夜在线电影| 在线成人国产| 国内在线观看一区二区三区| 国产精品亚发布| 国产精品免费在线| 国产精品成人播放| 欧美午夜精品久久久久免费视 | 亚洲高清毛片| 亚洲国产精品黑人久久久| 欧美福利影院| 亚洲福利视频二区| 亚洲黄色av一区| 亚洲精品久久久久久久久久久久久 | 亚洲大胆美女视频| 亚洲电影免费观看高清完整版| 狠狠色伊人亚洲综合成人| 国产一区91| 狠狠色狠狠色综合日日小说| 精品成人在线观看| 亚洲东热激情| 日韩视频亚洲视频| 亚洲视频免费| 久久成人免费网| 快播亚洲色图| 亚洲福利专区| 夜夜嗨av一区二区三区四区| 宅男噜噜噜66一区二区66| 亚洲男人的天堂在线| 欧美在线视屏 | 亚洲成人自拍视频| 日韩一级精品| 性欧美精品高清| 噜噜噜91成人网| 欧美午夜精品久久久久免费视| 国产日韩av在线播放| 在线电影一区| 在线视频你懂得一区| 午夜精品久久久久| 美女主播精品视频一二三四| 91久久久国产精品| 亚洲欧美在线一区二区| 久久人人爽人人爽爽久久| 欧美精品国产| 韩国成人理伦片免费播放| av不卡在线看| 久久久www成人免费无遮挡大片| 亚洲国产成人久久综合| 亚洲一区一卡| 蜜桃av一区二区三区| 国产精品久久久一区二区三区| 一区在线免费| 亚洲免费网站| 亚洲福利视频一区二区| 欧美亚洲在线视频| 欧美激情第10页| 国产一区二区视频在线观看| 亚洲精品一区二区三区99| 久久精品卡一| 在线亚洲美日韩| 欧美成人蜜桃| 国产自产高清不卡| 亚洲一级特黄| 亚洲国产一区二区在线| 久久成人久久爱| 国产精品美女久久久久久2018 | 欧美系列亚洲系列| 亚洲茄子视频| 亚洲欧美春色| 亚洲女爱视频在线| 亚洲国产精品v|