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

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

偶爾來避難的地方~

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

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

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

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

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

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

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

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

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

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

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

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ū)分開)

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

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

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

評論

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

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

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

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

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

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

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

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


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

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

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

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

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

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

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

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

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

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

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

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

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

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

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


只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产婷婷色一区二区三区在线| 香蕉乱码成人久久天堂爱免费| 免播放器亚洲| 久久大逼视频| 久久精品亚洲乱码伦伦中文| 香蕉久久a毛片| 欧美一区激情| 久久综合伊人77777| 免费不卡在线视频| 欧美大片18| 欧美视频免费在线观看| 国产精品亚洲不卡a| 国内精品久久久久久久影视麻豆| 亚洲国产精品一区二区第四页av| 99精品热视频| 久久国产黑丝| 亚洲国产精品ⅴa在线观看 | 欧美一区二区高清| 美腿丝袜亚洲色图| 亚洲精品一二| 新片速递亚洲合集欧美合集| 久久久噜噜噜久久中文字免| 欧美日韩国产天堂| 韩国女主播一区| 一区二区不卡在线视频 午夜欧美不卡'| 中国成人黄色视屏| 久久综合99re88久久爱| 一本色道久久综合亚洲精品婷婷 | 国产精品入口日韩视频大尺度| 国内精品美女av在线播放| 日韩天堂av| 玖玖精品视频| 黄色日韩在线| 亚洲网址在线| 欧美国产精品v| 午夜精品理论片| 欧美日韩在线免费| 1024亚洲| 久久久久91| 亚洲欧美www| 欧美视频中文字幕在线| 亚洲国产美女| 老司机成人网| 欧美一区二区精品| 国产精品另类一区| 亚洲一区二区三区777| 亚洲电影在线免费观看| 久久国产精品毛片| 国产视频精品网| 欧美一区影院| 亚洲午夜精品国产| 欧美亚洲成人精品| 亚洲一级黄色| 99国产精品久久久| 欧美激情按摩| 日韩亚洲精品电影| 亚洲国产视频一区| 欧美激情在线观看| 亚洲理伦在线| 亚洲精品国产精品国产自| 牛夜精品久久久久久久99黑人 | 国产综合亚洲精品一区二| 亚洲欧美日韩在线播放| 中文国产成人精品久久一| 欧美午夜精品伦理| 亚洲欧美在线免费观看| 亚洲一级二级在线| 国产精品毛片高清在线完整版| 亚洲伊人观看| 小嫩嫩精品导航| 黄色国产精品| 亚洲黑丝一区二区| 欧美日韩免费观看中文| 久久精品成人一区二区三区蜜臀 | 国产欧美日韩综合一区在线观看| 亚洲免费一在线| 一区二区三欧美| 国产精品丝袜久久久久久app| 欧美一区亚洲| 久久人人爽人人| 一区在线视频观看| 老**午夜毛片一区二区三区| 免费高清在线视频一区·| 亚洲免费小视频| 国产精品久久二区二区| 久久99在线观看| 久久视频在线看| 99国产精品久久久久久久成人热 | 亚洲国产精品一区| 欧美视频1区| 欧美一区二区三区四区在线观看 | 国产美女精品| 久久久www成人免费精品| 美女主播一区| 亚洲小说春色综合另类电影| 欧美一区二区三区免费在线看 | 亚洲国产精选| 一区二区三区黄色| 国产在线一区二区三区四区 | 久久成人一区二区| 99综合视频| 欧美一区二区三区视频在线 | 久久蜜桃资源一区二区老牛| 欧美福利视频网站| 午夜在线a亚洲v天堂网2018| 久久精品中文字幕一区二区三区| 亚洲人体1000| 欧美在线|欧美| 中日韩高清电影网| 久久精品视频在线播放| 亚洲欧美久久| 欧美激情一区二区三区不卡| 久久精品日产第一区二区| 欧美女同在线视频| 久久性天堂网| 国产伦精品一区二区三区视频孕妇| 91久久国产综合久久| 韩国欧美一区| 亚洲男同1069视频| 亚洲视频视频在线| 欧美国产精品va在线观看| 久久久久久网址| 国产欧美日韩精品a在线观看| 亚洲一区二区三区中文字幕在线| 久热成人在线视频| 亚洲男女自偷自拍| 一区二区三区毛片| 欧美国产亚洲视频| 理论片一区二区在线| 国产欧美日韩在线| 午夜精品电影| 欧美一区二区三区婷婷月色| 欧美视频手机在线| 亚洲精品专区| 一区二区三区视频在线| 欧美成人在线免费视频| 亚洲东热激情| 亚洲一区二区少妇| 亚洲综合视频在线| 国产精品高潮粉嫩av| 一区二区成人精品 | 香蕉成人啪国产精品视频综合网| 国产精品国产三级国产| 亚洲视频一二| 久久成人在线| 在线 亚洲欧美在线综合一区| 久久福利精品| 久久全球大尺度高清视频| 狠狠色狠狠色综合日日小说 | 国产精品亚洲а∨天堂免在线| 亚洲视频免费在线观看| 性一交一乱一区二区洋洋av| 国产麻豆日韩欧美久久| 午夜精品一区二区三区在线播放 | 久久久久久久91| 尤物九九久久国产精品的分类| 久久亚洲精品一区| 亚洲精品国产系列| 亚洲欧美视频| 伊人婷婷久久| 欧美精品在线观看播放| 一区二区久久| 久久激情视频久久| 最新亚洲激情| 国产精品jvid在线观看蜜臀| 欧美中文字幕久久| 91久久在线播放| 性伦欧美刺激片在线观看| 国产专区欧美专区| 欧美日本一道本| 久久成人18免费网站| 亚洲国产精品国自产拍av秋霞| 亚洲午夜精品福利| 国内在线观看一区二区三区| 欧美国产日韩在线| 亚洲综合日韩中文字幕v在线| 久久久亚洲高清| 久久永久免费| 99精品国产高清一区二区| 久久国产精品黑丝| 日韩午夜在线播放| 国内外成人免费激情在线视频| 欧美激情久久久久| 欧美在线视频一区二区三区| 亚洲伦理在线免费看| 狂野欧美激情性xxxx| 欧美一区二区在线免费观看| 老司机精品导航| 亚洲电影一级黄| 国产精品系列在线播放| 欧美精品久久久久a| 欧美伊人久久| 日韩亚洲欧美一区二区三区| 久久综合狠狠综合久久综青草| 亚洲午夜精品一区二区| 亚洲经典一区| 在线观看日韩www视频免费 | 在线观看一区二区视频| 国产乱码精品1区2区3区| 欧美mv日韩mv国产网站|