• <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>

            飯中淹的避難所~~~~~

            偶爾來(lái)避難的地方~

              C++博客 :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              94 隨筆 :: 0 文章 :: 257 評(píng)論 :: 0 Trackbacks

            1- 不要為每個(gè)小數(shù)據(jù)包發(fā)送一個(gè)IOCP請(qǐng)求,這樣很容易耗盡IOCP的內(nèi)部隊(duì)列.....從而產(chǎn)生10055錯(cuò)誤.

            2- 不要試圖在發(fā)送出IOCP請(qǐng)求之后,收到完成通知之前修改請(qǐng)求中使用的數(shù)據(jù)緩沖的內(nèi)容,因?yàn)樵谶@段時(shí)間,系統(tǒng)可能會(huì)來(lái)讀取這些緩沖.
             
            3- 為了避免內(nèi)存拷貝,可以嘗試關(guān)閉SOCKET的發(fā)送和接收緩沖區(qū),不過(guò)代價(jià)是,你需要更多的接收請(qǐng)求POST到一個(gè)數(shù)據(jù)流量比較大的SOCKET,從而保證系統(tǒng)一直可以找到BUFFER來(lái)收取到來(lái)的數(shù)據(jù).

            4- 在發(fā)出多個(gè)接收請(qǐng)求的時(shí)候,如果你的WORKTHREAD不止一個(gè),一定要使用一些手段來(lái)保證接收完成的數(shù)據(jù)按照發(fā)送接收請(qǐng)求的順序處理,否則,你會(huì)遇到數(shù)據(jù)包用混亂的順序排列在你的處理隊(duì)列里.....

            5- 說(shuō)起工作線程, 最好要根據(jù)MS的建議, 開(kāi) CPU個(gè)數(shù)*2+2 個(gè), 如果你不了解IOCP的工作原理的話.

            6- IOCP的工作線程是系統(tǒng)優(yōu)化和調(diào)度的, 自己就不需要進(jìn)行額外的工作了.如果您自信您的智慧和經(jīng)驗(yàn)超過(guò)MS的工程師, 那你還需要IOCP么....

            <new update @ 2008-3-7 1:00>
            7-發(fā)出一個(gè)Send請(qǐng)求之后,就不需要再去檢測(cè)是否發(fā)送完整,因?yàn)閕ocp會(huì)幫你做這件事情,有些人說(shuō)iocp沒(méi)有做這件事情,這和iocp的高效能是相悖的,并且我做過(guò)的無(wú)數(shù)次測(cè)試表明,Iocp要么斷開(kāi)連接,要么就幫你把每個(gè)發(fā)送請(qǐng)求都發(fā)送完整。

            8- 出現(xiàn)數(shù)據(jù)錯(cuò)亂的時(shí)候,不要慌,要從多線程的角度檢查你的解析和發(fā)送數(shù)據(jù)包的代碼,看看是不是有順序上的問(wèn)題。

            9- 當(dāng)遇到奇怪的內(nèi)存問(wèn)題時(shí),逐漸的減少工作線程的數(shù)量,可以幫你更快的鎖定問(wèn)題發(fā)生的潛在位置。

            10-同樣是遇到內(nèi)存問(wèn)題時(shí),請(qǐng)先去檢查你的客戶端在服務(wù)器端內(nèi)部映射對(duì)象的釋放是否有問(wèn)題。而且要小心的編寫(xiě)iocp完成失敗的處理代碼,防止引用一個(gè)錯(cuò)誤的內(nèi)部映射對(duì)象的地址。

            11- overlapped對(duì)象一定要保存在持久的位置,并且不到操作完成(不管成功還是失敗)不要釋放,否則可能會(huì)引發(fā)各種奇怪的問(wèn)題。

            12- IOCP的所有工作都是在獲取完成狀態(tài)的那個(gè)函數(shù)內(nèi)部進(jìn)行調(diào)度和完成的,所以除了注意工作線程的數(shù)量之外,還要注意,盡量保持足夠多的工作線程處在獲取完成狀態(tài)的那個(gè)等待里面,這樣做就需要減少工作線程的負(fù)擔(dān),確保工作線程內(nèi)部要處理費(fèi)時(shí)的工作。(我的建議是工作線程和邏輯線程徹底區(qū)分開(kāi))

            13- 剛剛想起來(lái),overlapped對(duì)象要為每次的send和recv操作都準(zhǔn)備一個(gè)全新的,不能圖方便重復(fù)利用。

            14- 盡量保持send和recv的緩沖的大小是系統(tǒng)頁(yè)面大小的倍數(shù),因?yàn)橄到y(tǒng)發(fā)送或者接收數(shù)據(jù)的時(shí)候,會(huì)鎖用戶內(nèi)存的,比頁(yè)面小的緩沖會(huì)浪費(fèi)掉整個(gè)一個(gè)頁(yè)面。(作為第一條的補(bǔ)充,建議把小包合并成大包發(fā)送)

            <未完待續(xù)>
            posted on 2007-04-14 08:44 飯中淹 閱讀(11421) 評(píng)論(16)  編輯 收藏 引用

            評(píng)論

            # re: 使用IOCP需要注意的一些問(wèn)題~~(不斷補(bǔ)充) 2007-04-15 16:34 ssss
            4- 在發(fā)出多個(gè)接收請(qǐng)求的時(shí)候,如果你的WORKTHREAD不止一個(gè),一定要使用一些手段來(lái)保證接收完成的數(shù)據(jù)按照發(fā)送接收請(qǐng)求的順序處理,否則,你會(huì)遇到數(shù)據(jù)包用混亂的順序排列在你的處理隊(duì)列里.....

            要采用什么手段呢?
            如果用序列號(hào),而每次序列號(hào)都不斷增加,這樣做不妥,有何好辦法?  回復(fù)  更多評(píng)論
              

            # re: 使用IOCP需要注意的一些問(wèn)題~~(不斷補(bǔ)充) 2007-04-15 19:23 飯中淹
            @ssss
            我采用Complete序列號(hào)和Post序列號(hào)的方法.
            每次發(fā)送一個(gè)RECV請(qǐng)求,Post序列號(hào)++.
            每次完成一個(gè)RECV就判斷一下Post序列號(hào)是否等于Complete序列號(hào),等于,就處理掉, Complete序列號(hào)++,如果,不等于,則保存到臨時(shí)數(shù)組,直到收到的RECV完成信息的Post序列號(hào)等于Complete序列號(hào),處理掉,并查看數(shù)組里的保存的那些是否等于++后的Complete序列號(hào),不斷重復(fù)處理和Complete序列號(hào)++,直到完成信息的Post序列號(hào)不等于Complete序列號(hào).

            這樣就能夠保證順序.  回復(fù)  更多評(píng)論
              

            # re: 使用IOCP需要注意的一些問(wèn)題~~(不斷補(bǔ)充)[未登錄](méi) 2007-04-18 00:43 eXile
            使用IOCP, 現(xiàn)在有一個(gè)asio, 用起來(lái)很簡(jiǎn)單的.
            另外可不可以問(wèn)一個(gè)問(wèn)題: UDP采用IOCP有沒(méi)有優(yōu)化效果?  回復(fù)  更多評(píng)論
              

            # re: 使用IOCP需要注意的一些問(wèn)題~~(不斷補(bǔ)充) 2007-04-18 02:02 飯中淹
            UDP用IOCP也有優(yōu)化效果.
            不過(guò)不是那么明顯.
            如果有很多個(gè)UDP端口一起在監(jiān)聽(tīng)和收發(fā),效果會(huì)明顯一點(diǎn).
              回復(fù)  更多評(píng)論
              

            # re: 使用IOCP需要注意的一些問(wèn)題~~(不斷補(bǔ)充)[未登錄](méi) 2008-04-03 12:19 kevin
            asio用來(lái)學(xué)習(xí)不錯(cuò),不推薦在項(xiàng)目中使用,會(huì)越用越郁悶。  回復(fù)  更多評(píng)論
              

            # re: 使用IOCP需要注意的一些問(wèn)題~~(不斷補(bǔ)充)[未登錄](méi) 2008-06-17 18:56 christanxw
            3- 為了避免內(nèi)存拷貝,可以嘗試關(guān)閉SOCKET的發(fā)送和接收緩沖區(qū),不過(guò)代價(jià)是,你需要更多的接收請(qǐng)求POST到一個(gè)數(shù)據(jù)流量比較大的SOCKET,從而保證系統(tǒng)一直可以找到BUFFER來(lái)收取到來(lái)的數(shù)據(jù).


            關(guān)閉SOCKET緩沖區(qū)一般并不能使性能得到提升。  回復(fù)  更多評(píng)論
              

            # re: 使用IOCP需要注意的一些問(wèn)題~~(不斷補(bǔ)充) 2008-09-16 14:00 proguru
            12條:
            “這樣做就需要減少工作線程的負(fù)擔(dān),確保工作線程內(nèi)部要處理費(fèi)時(shí)的工作?!?br>是不是應(yīng)該為
            “確保工作線程內(nèi)部_不_要處理費(fèi)時(shí)的工作?!?  回復(fù)  更多評(píng)論
              

            # re: 使用IOCP需要注意的一些問(wèn)題~~(不斷補(bǔ)充) 2008-12-11 14:03 lyq
            @kevin
            為啥子?  回復(fù)  更多評(píng)論
              

            # re: 使用IOCP需要注意的一些問(wèn)題~~(不斷補(bǔ)充) 2008-12-11 14:04 lyq
            # re: 使用IOCP需要注意的一些問(wèn)題~~(不斷補(bǔ)充)[未登錄](méi) 2008-04-03 12:19 kevin
            asio用來(lái)學(xué)習(xí)不錯(cuò),不推薦在項(xiàng)目中使用,會(huì)越用越郁悶。 回復(fù) 更多評(píng)論

            why?  回復(fù)  更多評(píng)論
              

            # re: 使用IOCP需要注意的一些問(wèn)題~~(不斷補(bǔ)充) 2008-12-25 17:14 minus
            13- 剛剛想起來(lái),overlapped對(duì)象要為每次的send和recv操作都準(zhǔn)備一個(gè)全新的,不能圖方便重復(fù)利用。

            我不認(rèn)為這樣合理,我只用兩個(gè),一個(gè)用來(lái)發(fā)送,一個(gè)用來(lái)接收  回復(fù)  更多評(píng)論
              

            # re: 使用IOCP需要注意的一些問(wèn)題~~(不斷補(bǔ)充) 2009-02-20 14:28 WGM001
            asio在項(xiàng)目中表現(xiàn)很不錯(cuò)的!
            即方便,又簡(jiǎn)單,也高效!推薦在項(xiàng)目中使用!  回復(fù)  更多評(píng)論
              

            # re: 使用IOCP需要注意的一些問(wèn)題~~(不斷補(bǔ)充) 2009-04-07 16:44 cbm
            不錯(cuò)的總結(jié),大部分支持  回復(fù)  更多評(píng)論
              

            # re: 使用IOCP需要注意的一些問(wèn)題~~(不斷補(bǔ)充) 2009-07-14 15:26 飛鴿傳書(shū)
            寫(xiě)得很詳細(xì),謝謝了。  回復(fù)  更多評(píng)論
              

            # re: 使用IOCP需要注意的一些問(wèn)題~~(不斷補(bǔ)充) 2011-04-06 11:31 lgc
            7-發(fā)出一個(gè)Send請(qǐng)求之后,就不需要再去檢測(cè)是否發(fā)送完整,因?yàn)閕ocp會(huì)幫你做這件事情,  回復(fù)  更多評(píng)論
              

            # re: 使用IOCP需要注意的一些問(wèn)題~~(不斷補(bǔ)充) 2011-09-20 18:19 菜鳥(niǎo)飛來(lái)
            7-發(fā)出一個(gè)Send請(qǐng)求之后,就不需要再去檢測(cè)是否發(fā)送完整,因?yàn)閕ocp會(huì)幫你做這件事情,有些人說(shuō)iocp沒(méi)有做這件事情,這和iocp的高效能是相悖的,并且我做過(guò)的無(wú)數(shù)次測(cè)試表明,Iocp要么斷開(kāi)連接,要么就幫你把每個(gè)發(fā)送請(qǐng)求都發(fā)送完整。
            --------------------------------------------------

            這里好像不對(duì)啊,MSDN上有提到說(shuō),一個(gè)WSASend操作在完成時(shí)有可能不能完全發(fā)送數(shù)據(jù)。這時(shí)你需要重新調(diào)用WSASend來(lái)發(fā)送剩下的數(shù)據(jù)。

            比如100字節(jié),只發(fā)送了60,那么還有40必須再次調(diào)用WSASend發(fā)送  回復(fù)  更多評(píng)論
              

            # re: 使用IOCP需要注意的一些問(wèn)題~~(不斷補(bǔ)充) 2012-04-15 22:14 xzhifei
            感謝樓主的提示,最近我就遇到了數(shù)據(jù)錯(cuò)亂,一直不得其解,直到看到你的文章,謝謝??!  回復(fù)  更多評(píng)論
              

            精品久久久久久无码人妻热 | 97精品国产97久久久久久免费| 久久精品无码专区免费| 久久青青草原精品国产软件| 99久久香蕉国产线看观香| 国内精品久久久久伊人av| 四虎国产精品免费久久5151| 欧美激情精品久久久久久久九九九| 少妇熟女久久综合网色欲| 国产精品久久波多野结衣| 亚洲精品无码久久久| 亚洲综合婷婷久久| 久久狠狠爱亚洲综合影院 | 亚洲精品乱码久久久久久蜜桃| 久久人人爽人人爽人人片AV不| 亚洲国产二区三区久久| 久久久久se色偷偷亚洲精品av| 国产一久久香蕉国产线看观看| 亚洲精品久久久www| 狠狠精品久久久无码中文字幕 | 26uuu久久五月天| 日韩精品久久无码人妻中文字幕| 久久精品国产一区| 国产成人精品三上悠亚久久| 开心久久婷婷综合中文字幕| 色综合久久最新中文字幕| 久久成人国产精品二三区| 久久亚洲私人国产精品vA| 伊人久久大香线蕉av一区| 99久久精品国产一区二区| 一级A毛片免费观看久久精品| 国产成人久久久精品二区三区| 久久超碰97人人做人人爱| 亚洲AV无一区二区三区久久 | 久久夜色tv网站| 久久er国产精品免费观看2| 精品一区二区久久久久久久网站| 国产精品国色综合久久| 99精品国产在热久久| 久久免费高清视频| 国产99久久久国产精免费|