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

            小明思考

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

            IOCP Tips

            Posted on 2008-03-12 11:51 小明 閱讀(6995) 評(píng)論(7)  編輯 收藏 引用 所屬分類: 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??梢杂肏asOverlappedIoCompleted來(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ò)。
            久久国产成人| 国产伊人久久| 精品久久久久久久国产潘金莲| 精品熟女少妇a∨免费久久| 久久狠狠爱亚洲综合影院| 97久久综合精品久久久综合| 久久综合狠狠综合久久激情 | 狠狠精品久久久无码中文字幕| 国产免费久久精品99re丫y| 中文字幕乱码人妻无码久久| 天天久久狠狠色综合| 久久99精品久久只有精品 | 欧美丰满熟妇BBB久久久| 精品久久国产一区二区三区香蕉| 国产一区二区三精品久久久无广告| 伊人色综合久久天天人守人婷| 久久综合综合久久97色| 日产精品久久久久久久| 日本精品一区二区久久久| 日本久久中文字幕| 国产真实乱对白精彩久久| 欧美熟妇另类久久久久久不卡 | 久久精品国产AV一区二区三区| 国内精品伊人久久久久| 久久久久久久波多野结衣高潮 | 四虎国产精品免费久久5151| 国内精品伊人久久久久av一坑 | 久久久久国产亚洲AV麻豆| 久久国产精品成人免费| 久久成人精品| 久久精品国产亚洲AV电影| 久久午夜夜伦鲁鲁片免费无码影视| 久久91这里精品国产2020| 亚洲欧美成人久久综合中文网| 亚洲中文字幕久久精品无码喷水| 无码专区久久综合久中文字幕| 久久婷婷五月综合97色一本一本| 精品久久香蕉国产线看观看亚洲| 午夜视频久久久久一区| 青青草原1769久久免费播放| 国产精品美女久久久久av爽|