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

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

            偶爾來避難的地方~

              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
              94 隨筆 :: 0 文章 :: 257 評論 :: 0 Trackbacks

            1- 不要為每個小數據包發(fā)送一個IOCP請求,這樣很容易耗盡IOCP的內部隊列.....從而產生10055錯誤.

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

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

            5- 說起工作線程, 最好要根據MS的建議, 開 CPU個數*2+2 個, 如果你不了解IOCP的工作原理的話.

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

            <new update @ 2008-3-7 1:00>
            7-發(fā)出一個Send請求之后,就不需要再去檢測是否發(fā)送完整,因為iocp會幫你做這件事情,有些人說iocp沒有做這件事情,這和iocp的高效能是相悖的,并且我做過的無數次測試表明,Iocp要么斷開連接,要么就幫你把每個發(fā)送請求都發(fā)送完整。

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

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

            10-同樣是遇到內存問題時,請先去檢查你的客戶端在服務器端內部映射對象的釋放是否有問題。而且要小心的編寫iocp完成失敗的處理代碼,防止引用一個錯誤的內部映射對象的地址。

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

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

            13- 剛剛想起來,overlapped對象要為每次的send和recv操作都準備一個全新的,不能圖方便重復利用。

            14- 盡量保持send和recv的緩沖的大小是系統(tǒng)頁面大小的倍數,因為系統(tǒng)發(fā)送或者接收數據的時候,會鎖用戶內存的,比頁面小的緩沖會浪費掉整個一個頁面。(作為第一條的補充,建議把小包合并成大包發(fā)送)

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

            評論

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

            要采用什么手段呢?
            如果用序列號,而每次序列號都不斷增加,這樣做不妥,有何好辦法?  回復  更多評論
              

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

            這樣就能夠保證順序.  回復  更多評論
              

            # re: 使用IOCP需要注意的一些問題~~(不斷補充)[未登錄] 2007-04-18 00:43 eXile
            使用IOCP, 現在有一個asio, 用起來很簡單的.
            另外可不可以問一個問題: UDP采用IOCP有沒有優(yōu)化效果?  回復  更多評論
              

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

            # re: 使用IOCP需要注意的一些問題~~(不斷補充)[未登錄] 2008-04-03 12:19 kevin
            asio用來學習不錯,不推薦在項目中使用,會越用越郁悶。  回復  更多評論
              

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


            關閉SOCKET緩沖區(qū)一般并不能使性能得到提升。  回復  更多評論
              

            # re: 使用IOCP需要注意的一些問題~~(不斷補充) 2008-09-16 14:00 proguru
            12條:
            “這樣做就需要減少工作線程的負擔,確保工作線程內部要處理費時的工作。”
            是不是應該為
            “確保工作線程內部_不_要處理費時的工作。”?  回復  更多評論
              

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

            # re: 使用IOCP需要注意的一些問題~~(不斷補充) 2008-12-11 14:04 lyq
            # re: 使用IOCP需要注意的一些問題~~(不斷補充)[未登錄] 2008-04-03 12:19 kevin
            asio用來學習不錯,不推薦在項目中使用,會越用越郁悶。 回復 更多評論

            why?  回復  更多評論
              

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

            我不認為這樣合理,我只用兩個,一個用來發(fā)送,一個用來接收  回復  更多評論
              

            # re: 使用IOCP需要注意的一些問題~~(不斷補充) 2009-02-20 14:28 WGM001
            asio在項目中表現很不錯的!
            即方便,又簡單,也高效!推薦在項目中使用!  回復  更多評論
              

            # re: 使用IOCP需要注意的一些問題~~(不斷補充) 2009-04-07 16:44 cbm
            不錯的總結,大部分支持  回復  更多評論
              

            # re: 使用IOCP需要注意的一些問題~~(不斷補充) 2009-07-14 15:26 飛鴿傳書
            寫得很詳細,謝謝了。  回復  更多評論
              

            # re: 使用IOCP需要注意的一些問題~~(不斷補充) 2011-04-06 11:31 lgc
            7-發(fā)出一個Send請求之后,就不需要再去檢測是否發(fā)送完整,因為iocp會幫你做這件事情,  回復  更多評論
              

            # re: 使用IOCP需要注意的一些問題~~(不斷補充) 2011-09-20 18:19 菜鳥飛來
            7-發(fā)出一個Send請求之后,就不需要再去檢測是否發(fā)送完整,因為iocp會幫你做這件事情,有些人說iocp沒有做這件事情,這和iocp的高效能是相悖的,并且我做過的無數次測試表明,Iocp要么斷開連接,要么就幫你把每個發(fā)送請求都發(fā)送完整。
            --------------------------------------------------

            這里好像不對啊,MSDN上有提到說,一個WSASend操作在完成時有可能不能完全發(fā)送數據。這時你需要重新調用WSASend來發(fā)送剩下的數據。

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

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

            嫩草伊人久久精品少妇AV| 欧美精品乱码99久久蜜桃| 久久久久亚洲精品天堂| 久久99精品久久久久久hb无码| 91精品国产91热久久久久福利| 国产精品激情综合久久| 久久av无码专区亚洲av桃花岛| 久久国产精品99国产精| 一级做a爰片久久毛片16| 99久久99久久精品国产| 久久久青草青青国产亚洲免观| 亚洲国产精品一区二区三区久久| 久久精品人妻一区二区三区| 日韩欧美亚洲综合久久影院Ds| 久久久久人妻一区精品色| 97精品国产97久久久久久免费| 久久婷婷色香五月综合激情| 色狠狠久久综合网| 久久国产免费观看精品| 超级97碰碰碰碰久久久久最新| 精品久久一区二区| 久久精品成人欧美大片| 国产精品va久久久久久久| 伊人久久大香线蕉AV色婷婷色| 久久www免费人成精品香蕉| 亚洲国产精品无码久久一区二区| 久久久青草青青亚洲国产免观| 一本大道久久香蕉成人网| 国产精品久久国产精品99盘| 亚洲国产欧洲综合997久久| 色婷婷狠狠久久综合五月| 亚洲国产成人久久综合一| 日本人妻丰满熟妇久久久久久| 亚洲国产精品高清久久久| 国产精品久久久天天影视香蕉 | 精品国产青草久久久久福利| 无码伊人66久久大杳蕉网站谷歌 | 思思久久99热只有频精品66| 亚洲伊人久久大香线蕉苏妲己| 91精品国产高清久久久久久io| 久久久久人妻一区精品色|