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

小明思考

高性能服務(wù)器端計(jì)算
posts - 70, comments - 428, trackbacks - 0, articles - 0
  C++博客 :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

IOCP Tips

Posted on 2008-03-12 11:51 小明 閱讀(7003) 評(píng)論(7)  編輯 收藏 引用 所屬分類(lèi): Win32Network/ACE

Tip 1 : 使用WSASend/WSARecv來(lái)收發(fā)數(shù)據(jù),而不是使用ReadFile/WriteFile
一句話,前者具有更好的性能

Tip 2:  理解IOCP的最大并發(fā)線程數(shù)和工作線程數(shù)
應(yīng)該讓工作線程數(shù)(調(diào)用GetQueuedCompletionStatus那些線程)大于等于在CreateIoCompletionPort 指定的NumberOfConcurrentThreads數(shù)。
標(biāo)準(zhǔn)做法是永遠(yuǎn)設(shè)置NumberOfConcurrentThreads=0

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

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

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


Tip 5: IOCP的清除
最重要的一點(diǎn)是,在I/O完成之前,不要釋放overlapped structure。可以用HasOverlappedIoCompleted來(lái)監(jiān)測(cè)OV是否完成。

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

Feedback

# re: IOCP Tips  回復(fù)  更多評(píng)論   

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

# re: IOCP Tips  回復(fù)  更多評(píng)論   

2008-03-12 15:13 by 請(qǐng)輸入你的姓名
Happy birthday.

# re: IOCP Tips  回復(fù)  更多評(píng)論   

2008-03-12 16:58 by 愛(ài)上龍卷風(fēng)
"標(biāo)準(zhǔn)做法是永遠(yuǎn)設(shè)置NumberOfConcurrentThreads=0"
這個(gè)應(yīng)該和cpu的數(shù)量相一致,而不是永遠(yuǎn)為0

# re: IOCP Tips  回復(fù)  更多評(píng)論   

2008-03-12 17:12 by 小明
@愛(ài)上龍卷風(fēng)
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  回復(fù)  更多評(píng)論   

2008-03-13 12:33 by 飯中淹
NumberOfConcurrentThreads是指定系統(tǒng)同時(shí)調(diào)度的工作線程數(shù).
如果你的工作線程的工作量很大,一定要把數(shù)量提升到比這個(gè)大.
這里的數(shù)量,最好和cpu的個(gè)數(shù)保持一個(gè)關(guān)系,這樣可以達(dá)到最高性能的調(diào)度。
比如等于cpu數(shù)量這樣一個(gè)選擇。

IOCP的工作線程的概念就是提供給系統(tǒng)一個(gè)可調(diào)度的完成操作所需的線程,這樣系統(tǒng)在獲取隊(duì)列的那個(gè)等待函數(shù)里面,就可以在內(nèi)核中對(duì)所有調(diào)用這個(gè)函數(shù)的工作線程進(jìn)行調(diào)度,在這些工作線程進(jìn)入內(nèi)核的部分處理完成隊(duì)列中的未完成操作,從而實(shí)現(xiàn)高性能的io。

明白了這個(gè)原理,就可以根據(jù)這個(gè)原理來(lái)合理的配置每個(gè)iocp需要的參數(shù)了。當(dāng)然,一個(gè)要注意的是,在獲取完成狀態(tài)的線程一定要大于等于你設(shè)置的這個(gè)同時(shí)調(diào)度的工作線程的個(gè)數(shù)的值,才能獲得最高的性能。

# re: IOCP Tips  回復(fù)  更多評(píng)論   

2008-03-14 19:32 by 追夢(mèng)時(shí)代
我關(guān)于避免多次調(diào)用WSARecv的做法是使用引用計(jì)數(shù). 不知道大家是怎么做的

# re: IOCP Tips  回復(fù)  更多評(píng)論   

2008-12-16 16:04 by 飛鴿傳書(shū)
IOCP,的確很不錯(cuò)。
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            牛牛国产精品| 欧美精品一区二区三区很污很色的 | 一本久久综合亚洲鲁鲁五月天| 欧美精品九九99久久| 欧美亚洲一区在线| 免费在线成人av| 在线免费高清一区二区三区| 久久五月激情| 久久视频一区| 亚洲国产精品一区二区第一页| 国产亚洲精品资源在线26u| 午夜精品视频在线观看| 亚洲男人第一av网站| 国产视频欧美| 麻豆freexxxx性91精品| 欧美成人在线免费观看| 亚洲麻豆av| 99伊人成综合| 国产亚洲精品成人av久久ww| 免费欧美电影| 欧美三级网页| 久久精品在线视频| 蜜桃久久av一区| 亚洲性视频网址| 午夜亚洲激情| 99国产精品99久久久久久| 亚洲午夜电影在线观看| 国产精品一二一区| 欧美韩国在线| 国产精品日产欧美久久久久| 久色成人在线| 国产精品美女久久久久久久 | 亚洲欧美一区二区三区久久 | 久久九九精品99国产精品| 亚洲国产婷婷综合在线精品| 亚洲最新合集| 亚洲国产精品ⅴa在线观看| 日韩图片一区| 亚洲成人自拍视频| 一本色道久久88亚洲综合88| 娇妻被交换粗又大又硬视频欧美| 亚洲综合色丁香婷婷六月图片| 久久亚洲国产成人| 欧美福利视频在线| 久久婷婷蜜乳一本欲蜜臀| 欧美xxx成人| 午夜精品视频在线观看| 欧美国产极速在线| 免费高清在线一区| 国产日韩欧美视频| 一本一本久久a久久精品综合妖精 一本一本久久a久久精品综合麻豆 | 久久夜色精品国产欧美乱极品| 欧美国产在线电影| 欧美一区二区高清在线观看| 美女露胸一区二区三区| 久久精品国产欧美激情| 国产精品视频男人的天堂| 亚洲精选大片| 亚洲国产精品成人综合色在线婷婷| 美女爽到呻吟久久久久| 一本色道精品久久一区二区三区| 亚洲高清成人| 亚洲欧美综合国产精品一区| 亚洲婷婷在线| 欧美日韩在线看| 最新成人av网站| 一区二区三区在线免费视频| 亚洲午夜电影网| 先锋影音一区二区三区| 国产精品色婷婷| 亚洲一本大道在线| 亚洲欧美日韩在线一区| 国产精品h在线观看| 一本一道久久综合狠狠老精东影业 | 久久久91精品| 国产色爱av资源综合区| 亚洲午夜日本在线观看| 亚洲欧美在线磁力| 欧美天堂在线观看| 亚洲视频综合| 欧美亚洲在线| 伊人久久噜噜噜躁狠狠躁| 久久精品国产综合| 欧美激情国产日韩| 最近看过的日韩成人| 欧美成人在线免费观看| 一本色道久久综合| 亚洲综合丁香| 国产日韩精品一区二区三区在线| 欧美大片一区二区| 亚洲欧洲美洲综合色网| 欧美日韩在线一区二区| 亚洲免费视频观看| 欧美高清你懂得| 亚洲一区国产视频| 韩国视频理论视频久久| 美女免费视频一区| 亚洲一区二区三区精品动漫| 久久精品五月| 日韩亚洲一区在线播放| 国产日韩欧美不卡| 欧美不卡激情三级在线观看| 一区二区精品国产| 可以看av的网站久久看| 在线观看欧美日韩| 国产精品久久9| 久久人91精品久久久久久不卡 | 国产欧美一区二区三区另类精品| 免费中文日韩| 亚洲美女中出| 国产亚洲综合精品| 欧美精品麻豆| 久久久视频精品| 亚洲无玛一区| 亚洲国产高清在线| 久久久精品久久久久| 在线一区二区三区做爰视频网站| 欧美成人免费观看| 午夜免费电影一区在线观看| 亚洲美女黄色片| 女主播福利一区| 久久国产欧美精品| 日韩一级网站| 亚洲国产欧美久久| 国产一区清纯| 欧美日韩午夜在线| 欧美黄污视频| 麻豆精品精华液| 亚洲精品国精品久久99热一| 日韩亚洲综合在线| 亚洲国产精品一区| 另类综合日韩欧美亚洲| 亚洲综合电影| 亚洲制服丝袜在线| 一本色道久久综合亚洲91 | 美女脱光内衣内裤视频久久网站| 国产精品久久二区二区| 欧美激情视频在线免费观看 欧美视频免费一 | 欧美黄色免费网站| 猫咪成人在线观看| 久久精品国产99精品国产亚洲性色 | 欧美日韩一区二区在线观看| 女女同性精品视频| 麻豆精品在线播放| 蜜桃久久精品一区二区| 美腿丝袜亚洲色图| 久久久久亚洲综合| 久久久国产成人精品| 久久精品中文字幕免费mv| 久久久99免费视频| 久热综合在线亚洲精品| 乱码第一页成人| 欧美高清免费| 欧美日韩视频在线观看一区二区三区| 日韩午夜视频在线观看| 亚洲免费不卡| 正在播放日韩| 午夜免费在线观看精品视频| 亚洲一二三四久久| 亚洲一区二区在线看| 午夜视频一区在线观看| 久久精品在线| 欧美激情亚洲国产| 国产精品乱码| 好看不卡的中文字幕| 亚洲区在线播放| 亚洲永久在线| 另类av导航| 亚洲精品综合久久中文字幕| 亚洲图片在线| 久久亚洲精品中文字幕冲田杏梨 | 欧美一区二区三区在线视频| 久久精品国产亚洲aⅴ| 免费视频亚洲| 一本一本久久| 久久亚洲国产精品日日av夜夜| 一区二区三区视频在线播放| 中国亚洲黄色| 久久精品水蜜桃av综合天堂| 欧美久久久久免费| 国产小视频国产精品| 亚洲免费不卡| 久久精品人人做人人综合| 亚洲第一久久影院| 午夜精品亚洲一区二区三区嫩草| 亚洲精品四区| 香蕉成人伊视频在线观看 | 亚洲第一天堂无码专区| 在线综合视频| 欧美成人国产| 国产精品美女一区二区| 亚洲国产综合91精品麻豆| 老牛影视一区二区三区| 久久成人亚洲| 亚洲免费成人| 久久综合久久综合久久| 国产丝袜一区二区三区| 亚洲破处大片| 免费观看成人鲁鲁鲁鲁鲁视频| 性8sex亚洲区入口|