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

            loop_in_codes

            低調做技術__歡迎移步我的獨立博客 codemaro.com 微博 kevinlynx

            WoW服務器模擬器Ascent網絡模塊分析

            Ascent網絡模塊

            Author: Kevin Lynx

             

            Ascent是WoW的服務器模擬器,你可以從它的SVN上獲取它的全部代碼,并從它的WIKI頁面獲取架構起整個服務器的相關步驟。

            基本架構:

            Ascent網絡模塊核心的幾個類關系如下圖所示:


            ThreadBase屬于Ascent線程池模塊中的類,它實現了一個job類,當其被加入到線程池中開始執行時,線程池管理器會為其分配一個線程(如果有線程資源)并多態調用到ThreadBase派生類的run函數。

            SocketWorkerThread用以代表IOCP網絡模型中的一個工作者線程,它會從IOCP結果隊列里取出異步IO的操作結果。這里的IOCP使用的完成鍵是Socket對象指針。SocketWorkerThread獲取到IO操作結果后,根據獲得的完成鍵將結果通知給具體的Socket對象。(Socket的說明見后面)

            ListenSocket代表一個監聽套接字。該網絡模塊其實只是簡單地將socket中的概念加以封裝。也就說,它依然把一個套接字分為兩種類型:監聽套接字和數據套接字(代表一個網絡連接)。所謂的監聽套接字,是指只可以在該套接字上進行監聽操作;而數據套接字則只可以在此套接字上進行發送、接收數據的操作。

            Socket代表我上面說的數據套接字。ListenSocket是一個類模板,為這個模板指定的模板參數通常是派生于Socket的類。其實這里使用了這個小技巧隱藏了工廠模式的細節。因為ListenSocket被放在一個單獨的線程里運作,當其接受到一個新的網絡連接時,就創建一個Socket派生類對象。(ListenSocket類如何知道這個派生類的類名?這就是通過類模板的那個模板參數)

            上層模塊通常會派生Socket類,實現一些IO操作的回調。也就說,當某個IO操作完成后,會通過Socket基類讓上層模塊獲取通知。

            SocketMgr是一個全局單件類。它主要負責一些網絡庫的全局操作(例如winsock庫的初始化),它還維護了一個容器,保存所有的Socket對象。這其實是它的主要作用。

            運作之一,接收新的連接

            接收新的網絡連接是通過ListenSocket實現的。在創建一個ListenSocket對象時,你需要指定它的模板參數。這個參數通常是一個派生于Socket的類。如下:

            ascent-logonserver/Main.cpp

                

            ListenSocket<AuthSocket> * cl = new ListenSocket<AuthSocket>(host.c_str(), cport);

             

            AuthSocket派生于Socket。創建ListenSocket時構造函數指定監聽IP和監聽端口。

             

            因為ListenSocket派生于ThreadBase,屬于線程池job,因此要讓ListenSocket工作起來,只需要將其加入到線程池管理器:

            ascent-logonserver/Main.cpp

             

            ThreadPool.ExecuteTask(cl);

             

            ListenSocket開始運作起來后,會阻塞式地WSAAccept。如果WSAAccept返回一個有效的套接字,ListenSocket就創建一個Socket派生類對象(類型由模板參數指定),在上面舉的例子中,也就是AuthSocket:

            ascent-logonserver/ ListenSocketWin32.h

                    

              socket = new T(aSocket); //創建AuthSocket并保存網絡套接字aSocket

                     socket
            ->SetCompletionPort(m_cp);//保存完成端口對象

                     socket
            ->Accept(&m_tempAddress); //關聯到完成端口等

            Accept函數最終會將新創建的Socket對象保存到SocketMgr對象內部維護的容器里。在這里,還會回調到上層模塊的OnConnect函數,從而實現信息捕獲。

            運作之二,接收數據

            在windows平臺下,該網絡模塊使用的是IOCP模型,屬于異步IO。當接收新的連接時,即發出WSARecv的IO操作。在工作者線程中,也就是SocketWorkerThread中,會根據IOCP完成鍵得到Socket對象指針,然后根據不同的IO操作結果多態回調到Socket派生類對應的函數。例如如果是WSARecv完成,則調用到AuthSocket::OnRead函數(上述例子)。OnRead函數直接可以獲取到保存數據的緩沖區指針。事實上,每一個Socket對象在被創建時,就會自動創建接收緩沖區以及發送緩沖區。

            運作之三,發送數據

            分析到這里,我們可以看出,該網絡模塊實現得很一般。在接受數據部分,網絡工作者線程回調到對應的Socket對象,Socket直接對數據進行上層邏輯處理。更好的做法是當工作者線程回調到上層Socket(Socket的派生類)時,這里應該簡單地將數據組織成上層數據包并放入上層數據包隊列,讓上層邏輯稍后處理,而不是讓網絡模塊自己去處理。這樣做主要是考慮到多線程模型。

            同樣,該網絡模塊的發送模塊也是一樣,沒有緩沖機制。當要發送數據時,直接調用到Socket的Send函數。該函數拷貝用戶數據到自己維護的發送緩沖區,然后將自己的緩沖區指針直接提交給IOCP,WSASend發送。

             

            結束

            該網絡模塊實現的似乎有點簡陋,在該模塊之上也沒有數據校驗、數據加密的模塊(這些動作散亂地分布在最上層邏輯)。在架構上也沒能很好地將概念區分開來,Socket套用了原始socket中的數據套接字,而不是我所希望的NetSession。可以圈點的地方在于該模塊很多地方使用了回調函數表,從而方便地實現事件傳送。

             

            posted on 2008-04-02 21:22 Kevin Lynx 閱讀(4448) 評論(4)  編輯 收藏 引用 所屬分類: game develop

            評論

            # re: WoW服務器模擬器Ascent網絡模塊分析 2008-04-11 13:47 Bugs

            已閱  回復  更多評論   

            # re: WoW服務器模擬器Ascent網絡模塊分析 2008-07-21 21:41 是是

            海星  回復  更多評論   

            # re: WoW服務器模擬器Ascent網絡模塊分析 2010-06-23 11:25 游客

            ascent代碼還能獲取嗎?
            請問svn地址?  回復  更多評論   

            # re: WoW服務器模擬器Ascent網絡模塊分析[未登錄] 2011-03-11 16:48 BERT

            “我們可以看出,該網絡模塊實現得很一般。在接受數據部分,網絡工作者線程回調到對應的Socket對象,Socket直接對數據進行上層邏輯處理。”

            博主沒仔細看吧?
            虛函數OnRead做了解包,將數據組織成上層數據包并放入上層數據包隊列,讓上層邏輯稍后處理  回復  更多評論   

            久久久久亚洲AV成人网人人网站 | 精品久久久久中文字幕一区| 久久精品国产亚洲AV无码偷窥| 亚洲国产另类久久久精品| 国产精品久久久久久| 久久激情亚洲精品无码?V| 亚洲中文字幕无码久久2020| 久久精品无码专区免费东京热| 777久久精品一区二区三区无码| 亚洲精品成人久久久| 久久精品a亚洲国产v高清不卡| 国产精品亚洲美女久久久| 伊色综合久久之综合久久| 国产精品福利一区二区久久| 久久影院久久香蕉国产线看观看| 久久天天躁狠狠躁夜夜网站| 久久久久亚洲av成人无码电影 | 狠狠色婷婷久久综合频道日韩| 狠狠88综合久久久久综合网| 中文字幕精品久久| 久久精品夜色噜噜亚洲A∨| 国产亚洲精品美女久久久| 日本WV一本一道久久香蕉| 久久伊人五月天论坛| 伊人久久大香线焦综合四虎 | 久久91综合国产91久久精品| 日本久久久久久久久久| 精品久久久久久无码国产| 国产精品无码久久综合| 久久久久久久波多野结衣高潮| 日韩美女18网站久久精品| 久久精品国产亚洲7777| 国产精自产拍久久久久久蜜| 久久香蕉国产线看观看乱码| 2022年国产精品久久久久| 天堂久久天堂AV色综合| 久久综合九色综合网站| 精品国产一区二区三区久久久狼| 久久永久免费人妻精品下载| 久久无码人妻一区二区三区午夜| 久久精品中文无码资源站|