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

            小明思考

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

            IOCP Tips

            Posted on 2008-03-12 11:51 小明 閱讀(6995) 評論(7)  編輯 收藏 引用 所屬分類: Win32 、Network/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,的確很不錯。
            久久99热这里只有精品国产| 亚洲精品无码专区久久同性男| 国产精品岛国久久久久| 国产99精品久久| 蜜臀久久99精品久久久久久| 亚洲中文久久精品无码ww16| 久久精品国产亚洲5555| 久久夜色精品国产噜噜噜亚洲AV| 国内精品久久久久国产盗摄| 中文字幕人妻色偷偷久久| 久久精品国产亚洲7777| 99久久精品国内| 伊人久久精品无码二区麻豆| 久久人人爽人人精品视频| 狠狠色丁香久久综合婷婷| 久久精品国产免费观看| 久久亚洲中文字幕精品一区四| 久久精品中文騷妇女内射| 久久无码专区国产精品发布| 狠狠综合久久综合中文88| 久久99精品国产99久久| 精品无码久久久久久午夜| 中文字幕乱码人妻无码久久| 亚洲国产精品成人久久蜜臀 | 大香伊人久久精品一区二区 | 亚洲午夜无码久久久久| 日本高清无卡码一区二区久久| 国产成人久久久精品二区三区| 久久国产精品-国产精品| 91精品国产乱码久久久久久| 一本一道久久综合狠狠老| 老男人久久青草av高清| 人妻少妇精品久久| 亚洲欧美一级久久精品| 性欧美大战久久久久久久| 亚洲精品午夜国产va久久| 伊人热热久久原色播放www | 国产韩国精品一区二区三区久久| 久久久久久亚洲AV无码专区| 久久精品99久久香蕉国产色戒| 国产精品禁18久久久夂久|