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

小明思考

高性能服務器端計算
posts - 70, comments - 428, trackbacks - 0, articles - 0
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

IOCP Tips

Posted on 2008-03-12 11:51 小明 閱讀(6999) 評論(7)  編輯 收藏 引用 所屬分類: Win32Network/ACE

Tip 1 : 使用WSASend/WSARecv來收發數據,而不是使用ReadFile/WriteFile
一句話,前者具有更好的性能

Tip 2:  理解IOCP的最大并發線程數和工作線程數
應該讓工作線程數(調用GetQueuedCompletionStatus那些線程)大于等于在CreateIoCompletionPort 指定的NumberOfConcurrentThreads數。
標準做法是永遠設置NumberOfConcurrentThreads=0

Tip 3: 利用GetQueuedCompletionStatus的completion key和overlapped structure參數在異步操作中來傳遞信息
通常completion key用來傳遞和handle/socket/session的信息
而overlapped structure用來傳遞每次異步I/O的一些信息,通常的做法是會定義一個structure來派生于OVERLAPPED
struct MY_IO_DATA : public OVERLAPPED

Tip 4: 理解IOCP的完成包的排隊行為
從GetQueuedCompletionStatus得到完成包的次序可能跟調用WSASend/WSARecv的次序不一樣。
微軟唯一保證是如果調用WSASend/WSARecv得到SUCCESS或者IO_PENDING,就一定會有一個完成包出現在IOCP的隊列上,不管這個socket是否關閉了。
如果關閉socket,那么之后的WSASend/WSARecv調用就一定返回失敗的結果。

關于IOCP包可能次序錯亂和解決方法,有一篇文章可以參考: http://www.codeproject.com/KB/IP/reusablesocketserver4.aspx
我的做法是避免多次調用WSARecv


Tip 5: IOCP的清除
最重要的一點是,在I/O完成之前,不要釋放overlapped structure。可以用HasOverlappedIoCompleted來監測OV是否完成。

通常的做法是
1) 調用PostQueueCompletionStatus N次(N=工作線程數),來傳遞特殊的退出信息給所有的工作線程
2) 關閉所有的socket,如果很在意處理完未完成的數據包,需要使用一個計數器來跟蹤異步I/O事件,直到計數器為0,才關閉相應的socket
3) 關閉completion port

Feedback

# re: IOCP Tips  回復  更多評論   

2008-03-12 12:35 by 李侃
應該把OVERLAPPED 結構(一個或多個)綁定到你的session上去,避免OVERLAPPED 被多個用戶共用,會減少很多“不必要”的麻煩,另外一個OVERLAPPED 做完一件事情之前,不要讓它再去做另外一件事情,這兩點是我比較深刻的體會,

# re: IOCP Tips  回復  更多評論   

2008-03-12 15:13 by 請輸入你的姓名
Happy birthday.

# re: IOCP Tips  回復  更多評論   

2008-03-12 16:58 by 愛上龍卷風
"標準做法是永遠設置NumberOfConcurrentThreads=0"
這個應該和cpu的數量相一致,而不是永遠為0

# re: IOCP Tips  回復  更多評論   

2008-03-12 17:12 by 小明
@愛上龍卷風
From MSDN:
NumberOfConcurrentThreads
If this parameter is zero, the system allows as many concurrently running threads as there are processors in the system.

# re: IOCP Tips  回復  更多評論   

2008-03-13 12:33 by 飯中淹
NumberOfConcurrentThreads是指定系統同時調度的工作線程數.
如果你的工作線程的工作量很大,一定要把數量提升到比這個大.
這里的數量,最好和cpu的個數保持一個關系,這樣可以達到最高性能的調度。
比如等于cpu數量這樣一個選擇。

IOCP的工作線程的概念就是提供給系統一個可調度的完成操作所需的線程,這樣系統在獲取隊列的那個等待函數里面,就可以在內核中對所有調用這個函數的工作線程進行調度,在這些工作線程進入內核的部分處理完成隊列中的未完成操作,從而實現高性能的io。

明白了這個原理,就可以根據這個原理來合理的配置每個iocp需要的參數了。當然,一個要注意的是,在獲取完成狀態的線程一定要大于等于你設置的這個同時調度的工作線程的個數的值,才能獲得最高的性能。

# re: IOCP Tips  回復  更多評論   

2008-03-14 19:32 by 追夢時代
我關于避免多次調用WSARecv的做法是使用引用計數. 不知道大家是怎么做的

# re: IOCP Tips  回復  更多評論   

2008-12-16 16:04 by 飛鴿傳書
IOCP,的確很不錯。
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲久久成人| 国内精品久久久久久| 亚洲另类视频| 亚洲人成网站777色婷婷| 女生裸体视频一区二区三区| 亚洲麻豆一区| 99在线观看免费视频精品观看| 欧美视频在线一区二区三区| 香蕉尹人综合在线观看| 久久国产黑丝| 亚洲国产精品一区二区第一页| 亚洲欧洲一区二区三区| 黑人巨大精品欧美一区二区小视频| 午夜在线成人av| 欧美一区二区视频在线| 亚洲第一精品在线| 亚洲区国产区| 国产欧美一区二区精品秋霞影院| 久久久蜜桃精品| 欧美成人综合网站| 欧美一级免费视频| 麻豆亚洲精品| 先锋影音久久| 欧美ed2k| 久久综合中文字幕| 欧美精品一区二区三区四区| 久久本道综合色狠狠五月| 欧美大片91| 久久视频国产精品免费视频在线| 欧美肥婆bbw| 久久精品日产第一区二区三区 | 欧美在线观看一区| 女人香蕉久久**毛片精品| 午夜一区在线| 欧美日本乱大交xxxxx| 久久在线免费视频| 国产精品久久看| 最新日韩av| 亚洲国产成人午夜在线一区| 亚洲欧美www| 亚洲素人在线| 欧美精品在线免费播放| 欧美aa在线视频| 国产亚洲精品一区二555| 99国产精品国产精品久久| 亚洲国产成人精品女人久久久 | 亚洲国产日韩在线| 久久国产精品亚洲va麻豆| 午夜国产精品视频| 欧美日韩国产欧美日美国产精品| 久久综合九色综合欧美就去吻| 国产精品久久久久久久第一福利 | 久久成人免费| 国产精品男人爽免费视频1| 99国产麻豆精品| 亚洲私人影院在线观看| 欧美区亚洲区| 亚洲人成在线播放| 亚洲激情视频在线| 蜜桃视频一区| 亚洲国产成人tv| 亚洲三级色网| 欧美激情视频一区二区三区在线播放 | 久久久青草青青国产亚洲免观| 国产精品一区二区欧美| 亚洲影音先锋| 亚洲男女毛片无遮挡| 午夜精品短视频| 国产精品乱码一区二区三区| 99精品福利视频| 亚洲视频精品在线| 欧美亚男人的天堂| 亚洲影院色无极综合| 久久国产日本精品| 精东粉嫩av免费一区二区三区| 久久久国产精彩视频美女艺术照福利 | 欧美日韩精品一区二区天天拍小说 | 媚黑女一区二区| 亚洲人成免费| 欧美日韩国产一中文字不卡| 一本色道久久88综合日韩精品| 亚洲免费婷婷| 国产一区二区三区久久精品| 久久久久久欧美| 欧美黄色免费网站| 一区二区三区日韩精品| 国产精品日韩专区| 久久久精品动漫| 亚洲欧洲综合| 欧美一区二区三区在线观看视频| 韩国一区二区三区在线观看| 欧美成人蜜桃| 亚洲婷婷综合久久一本伊一区| 久久精品国产亚洲精品| 亚洲人成绝费网站色www| 欧美性色视频在线| 久久精品视频99| 99ri日韩精品视频| 久久久久久久性| 亚洲人成人77777线观看| 国产精品国产三级国产aⅴ9色| 久久精品亚洲热| 夜夜嗨av一区二区三区免费区| 久久久久久久综合| 一区二区三区久久精品| 国内精品国产成人| 欧美日韩一级黄| 久久久久中文| 亚洲一区二区三区在线| 亚洲国产精品小视频| 欧美在线三区| 一区二区免费在线播放| 在线观看一区二区视频| 国产精品任我爽爆在线播放| 免费观看国产成人| 亚洲欧美在线网| 亚洲久色影视| 欧美成人午夜免费视在线看片| 亚洲欧美日韩在线高清直播| 亚洲免费精彩视频| 激情久久久久久| 国产精品资源| 国产精品成人一区| 欧美区日韩区| 欧美成人蜜桃| 老司机精品福利视频| 欧美专区日韩专区| 亚洲欧美日韩一区二区三区在线观看 | 韩日欧美一区二区三区| 欧美婷婷久久| 欧美激情亚洲国产| 久久偷窥视频| 欧美在线一二三四区| 亚洲专区一区| 亚洲视频福利| 一区二区三区 在线观看视频| 亚洲国产高潮在线观看| 亚洲第一福利在线观看| 亚洲电影第1页| 欧美激情一区二区三区| 亚洲二区在线| 亚洲黑丝在线| 亚洲精品国产视频| 日韩视频在线观看免费| 日韩一级大片| 亚洲私拍自拍| 亚洲欧美国产日韩天堂区| 亚洲欧美日韩精品综合在线观看| 亚洲免费视频网站| 久久av资源网站| 久久嫩草精品久久久精品| 久久亚洲精品网站| 欧美sm重口味系列视频在线观看| 欧美成人蜜桃| 欧美日韩午夜在线视频| 国产精品久久久久久久久久三级 | 亚洲电影第1页| 亚洲人成网站影音先锋播放| 99国产精品久久久久久久久久| 亚洲天堂网站在线观看视频| 亚洲欧美国产日韩天堂区| 小黄鸭视频精品导航| 久久男人资源视频| 亚洲二区免费| 亚洲天堂网站在线观看视频| 久久成人免费网| 欧美成人免费全部| 国产精品久久久久久影视| 国产欧美一区二区三区国产幕精品 | 久久久久国产精品午夜一区| 欧美成人一区二免费视频软件| 欧美色欧美亚洲另类二区| 国产麻豆成人精品| 亚洲国产成人精品视频| 亚洲网在线观看| 久久嫩草精品久久久精品一| 亚洲欧洲一区二区天堂久久| 亚洲欧美日韩天堂| 男男成人高潮片免费网站| 国产精品久久二区二区| 在线观看免费视频综合| 亚洲欧美三级伦理| 欧美顶级艳妇交换群宴| 亚洲图片激情小说| 欧美大片一区二区三区| 国产主播喷水一区二区| 99国产精品久久久久老师| 久久久亚洲人| 亚洲天堂av在线免费| 欧美成人一区二区三区片免费| 国产欧美一区二区三区在线看蜜臀| 最新国产成人av网站网址麻豆| 欧美中文在线免费| 亚洲伦理久久| 免费观看成人网| 国内精品伊人久久久久av一坑| 亚洲女女女同性video| 亚洲高清毛片| 久久久亚洲影院你懂的| 国产欧美在线|