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

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 閱讀(4480) 評論(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做了解包,將數據組織成上層數據包并放入上層數據包隊列,讓上層邏輯稍后處理  回復  更多評論   

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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蜜臀| 久久精品人人做人人综合| 亚洲一区二区少妇| 99精品视频免费观看视频| 日韩亚洲国产精品| 日韩视频亚洲视频| 91久久亚洲| 亚洲国产婷婷香蕉久久久久久| 亚洲欧洲另类| 亚洲综合三区| 免费不卡欧美自拍视频| 欧美日韩一区三区| 国内成人自拍视频| 一二三区精品| 久久久五月天| 日韩视频在线一区二区三区| 久久精品亚洲国产奇米99| 欧美日韩国产限制| 国产精品视频网址| 日韩天堂在线视频| 久久亚洲捆绑美女| 亚洲一区国产| 欧美三区美女| 性欧美超级视频| 亚洲国产免费看| 国产精品高潮呻吟久久| 国产日韩成人精品| 欧美国产一区在线| 国产精品久久久久久久久久久久久 | 国产精品久99| 国产欧美精品xxxx另类| 亚洲人成77777在线观看网| 亚洲欧美中文在线视频| 欧美黑人在线观看| 欧美中文字幕在线| 国产精品久久久久婷婷| 亚洲激情校园春色| 欧美在线观看你懂的| 欧美精品色网| 亚洲影院污污.| 久久爱www久久做| 在线观看中文字幕不卡| 欧美激情视频网站| 欧美三级乱人伦电影| 亚洲小少妇裸体bbw| 欧美一级一区| 亚洲欧美另类综合偷拍| 久久久水蜜桃| 一区二区成人精品 | 最新亚洲激情| 欧美电影免费观看网站| 亚洲欧美日韩成人高清在线一区| 一区二区三区欧美在线| 亚洲日本黄色| 午夜视频一区二区| 在线亚洲伦理| 午夜免费电影一区在线观看| 欧美电影免费观看高清| 亚洲激情六月丁香| 亚洲欧美国产三级| 亚洲第一在线综合在线| 欧美日韩国产在线播放网站| 免播放器亚洲| 国内外成人在线视频| 久久激情五月丁香伊人| 亚洲一区在线视频| 欧美国产日韩在线| 亚洲黄色免费| 亚洲精品视频在线| 欧美久久久久久久| 亚洲视频第一页| 亚洲特黄一级片| 欧美福利视频在线观看| 蜜臀av国产精品久久久久| 国产一区清纯| 久久亚洲午夜电影| 91久久国产自产拍夜夜嗨| 亚洲第一在线| 欧美精品二区三区四区免费看视频| 欧美大色视频| 亚洲视频在线观看| 欧美精品久久久久久久久久| 日韩视频在线观看| 免费在线日韩av| 99国产麻豆精品| 国产精品中文字幕在线观看| 亚洲欧美国产精品专区久久| 欧美日韩一区二区精品| 亚洲福利视频在线| 午夜激情综合网| 最新国产成人av网站网址麻豆| 欧美日韩三级在线| 欧美精品久久久久久久免费观看| 99在线精品观看| 亚洲国产精品999| 性色一区二区| 中文欧美在线视频| 黄色成人在线网站| 国产精品你懂的在线欣赏| 欧美不卡视频| 久久欧美肥婆一二区| 99国内精品久久久久久久软件| 午夜视频久久久久久| 99这里只有精品| 日韩一级大片| 亚洲一区自拍| 久久在线免费观看| 欧美激情视频在线播放| 99热精品在线| 欧美一区成人| 欧美人成在线视频| 在线高清一区| 亚洲影音一区| 亚洲国产合集| 久久亚洲不卡| 国产一区二区三区在线观看网站| 欧美日本一区| 国产精品免费一区二区三区在线观看| 午夜精品成人在线| 午夜视频久久久| 亚洲国产欧美日韩精品| 最新国产拍偷乱拍精品| 在线中文字幕一区| 亚洲一区视频在线观看视频| 亚洲欧美日韩成人| 久久婷婷成人综合色| 欧美成熟视频| 国产精品久久午夜夜伦鲁鲁| 亚洲精品一区二区三区蜜桃久| 日韩视频一区二区三区| 亚洲欧美日韩系列| 欧美1区2区3区| 国产精品日日摸夜夜添夜夜av| 国产精品婷婷| 一个色综合av| 欧美激情黄色片| 欧美一区二区免费视频| 欧美日韩三级在线| 亚洲黄色在线视频| 久久精品国产清高在天天线| 亚洲乱码国产乱码精品精98午夜 | 国内不卡一区二区三区| 99re视频这里只有精品| 麻豆精品传媒视频| 欧美在线影院在线视频| 国产精品成人播放| 亚洲视频www| 日韩亚洲国产精品| 欧美视频一区二区三区四区| 好吊色欧美一区二区三区视频| 欧美一区成人| 香蕉久久国产| 国内激情久久| 亚洲国产欧美精品| 欧美区亚洲区| 亚洲一区二区3| 亚洲无玛一区| 国内精品**久久毛片app| 久久久久久久久久久久久久一区| 欧美一级淫片aaaaaaa视频| 亚洲丶国产丶欧美一区二区三区| 免费观看欧美在线视频的网站| 欧美成人自拍视频| 亚洲欧美日韩在线一区| 久久精品在线| 中文网丁香综合网| 久久久视频精品| 一区二区欧美国产| 久久精品免费电影| 一本大道av伊人久久综合| 99热免费精品在线观看| 久久久久综合| 亚洲一区二区影院| 久久精品夜夜夜夜久久| 亚洲神马久久| 免费短视频成人日韩| 香蕉av777xxx色综合一区| 免费成人在线观看视频| 久久av二区| 国产精品久久久免费| 嫩草成人www欧美| 国产精品亚洲网站| 中文在线不卡| av成人免费观看| 久久午夜电影| 欧美黄色一级视频| 又紧又大又爽精品一区二区| 先锋亚洲精品| 欧美亚洲三区| 国产精品自拍一区| 亚洲一区二区三区777| 亚洲女人天堂成人av在线| 国产精品vip| 亚洲欧美精品在线| 久久久人成影片一区二区三区观看 | 亚洲男人天堂2024| 欧美日韩www| 在线亚洲国产精品网站|