• <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 - 82,  comments - 7,  trackbacks - 0
              MMORPG不同于其它的局域網的網絡游戲,它是一個面向整個Internet的連接人數過萬的網絡游戲,因此他的服務器端設計則極為重要
              
              服務器的基本設置
              
              在大型網絡游戲里,通常設計為C/S結構,客戶端不再對數據進行邏輯處理,而只是一個收發裝置,從玩家那里接受到操作信息,然后反饋給服務器,再由服務器進行處理后發回客戶端,經客戶端通過圖形化處理,給玩家呈現出一個繽紛的游戲世界。
               
              登陸服務器
              
              在這里也可以稱之為連接服務器,網絡游戲的客戶端一般是連接到這里,然后再由該連接服務器根據不同的需要,把游戲消息轉發給其它相應的服務器(邏輯和地圖服務器)也因為它是客戶端直接連接的對象,它同時也負擔了驗證客戶身份的工作。
              
              地圖服務器
              
              在這里也可以稱之為連續事件服務器。在這個服務器里要處理的對象(玩家)所做的動作都是一個連續事件。例如玩家從A點移動到B點,這樣一個動作,需要一定的時間進行移動,因此說移動是一個連續事件。
              
              邏輯服務器
              
            在這里可以稱之為瞬時事件服務器,在這個服務器里,處理對象(玩家)所做的動作均可以在非常斷時間內完成完成。例如玩家從商店購買一瓶藥書,當玩家確認 購買后,服務器先扣除玩家的游戲幣,然后再把相應的藥水瓶加入玩家的背包里。這2個操作對于服務器來說,只是2個數字的加減,計算完這兩個數字的加減,這 個事件就可以結束了。因此,我們可以說這個事件是一個瞬時事件
              
              服務器組的改進
              
              不過在實際應用的過程中,游戲服務器的結構要比上面所說的3種服務結構要復雜些,不過也都是在這3種最基本的服務器架構下進行擴充,擴充的主要是其它輔助功能。在實際應用里可能增加的2種服務器,數據庫服務器,計費服務器,由邏輯服務器獨立出來的聊天服務器。
               
              數據庫服務器
              
              數據庫服務器其實就是專門利用一臺服務器進行數據庫的讀寫操作。這點特別是在大型的網絡游戲里尤為重要。因為在大型網絡游戲里,要處理玩家的數據量非常大,如果不利用專門的服務器進行處理,很有可能會拖累這個服務器組。
              
              計費服務器
              
              通常在商業的網絡游戲里出現,用于記錄玩家在線的時間,給收費提供依據,同時也是整個服務器組里最重要的部分,一旦出現問題,運營商就不用賺錢了。
              
              聊天服務器
              
              在游戲里的聊天功能是屬于一種瞬時動作,理論上是放在邏輯服務器里進行處理。不過在大型網絡游戲里,因為這個部分功能與游戲里的其它部分聯系并不緊密,因此可以獨立出來做一個功能服務器。
              
              服務器的集群設置
              
              在大型游戲的應用過程中,實際需要處理的玩家數量可能過萬,一臺普通的服務器是無法完成所要完成的工作,因此,在實際應用的時候,通常是由一組多臺服務器共同完成一個功能。
              例如地圖服務器,可以根據需要,把游戲里所有的地域進行劃分,劃分為N個區域,然后讓這一個區域里發生的事件都用一個特定的服務器進行處理。這樣做的目的是減少一個服務器所承擔的計算量,把整個系統組成一個分布式的網絡。
            不過這樣做的同時會造成一個麻煩:當一位玩家從區域1,移動到區域2。這個時候,就必須先在服務器1里把玩家刪除,然后再在區域2里加入玩家。同時需要 由服務器1向服務器2轉移玩家的數據信息(因為服務器組在工作的時候,玩家的信息只能保存在當前所在區域的服務器里),也就是說一旦玩家發生服務器間區域 移動,服務器端就不可避免的造成數據通訊。因為這種移動并不是有規律的,玩家所在的服務器都有可能到達其它服務器。這樣,如果服務器組里有N臺地圖服務 器,那么,每個服務器都可能向其它N-1臺服務器產生連接,總共就可能產生N×N個連接。如此數量連接如果只是使用普通的socket設計,就很有可能會 給服務器通訊間的各種問題所困擾,為此,在商業網絡游戲的服務器之間,通常都使用成熟的第三方的通訊中間件,如ACE,ICE等作為網絡連接的傳輸層。
              
            posted on 2009-09-14 13:29 暗夜教父 閱讀(1630) 評論(1)  編輯 收藏 引用 所屬分類: Game Development

            FeedBack:
            # re: 深入剖析MMORPG游戲服務器端的設計[未登錄]
            2010-01-25 15:37 | helloworld
            good  回復  更多評論
              

            <2010年3月>
            28123456
            78910111213
            14151617181920
            21222324252627
            28293031123
            45678910

            常用鏈接

            留言簿(2)

            隨筆分類

            隨筆檔案

            文章分類

            文章檔案

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            亚洲色欲久久久久综合网| 国内精品九九久久久精品| 久久国产V一级毛多内射| 欧美一级久久久久久久大| 区亚洲欧美一级久久精品亚洲精品成人网久久久久| 久久综合九色欧美综合狠狠 | 久久伊人五月天论坛| 午夜精品久久久久久| 精品久久久久香蕉网| 久久成人精品| 久久综合中文字幕| 久久无码中文字幕东京热| 国产亚洲成人久久| 久久免费精品一区二区| 久久婷婷人人澡人人爽人人爱| 亚洲一区中文字幕久久| 婷婷伊人久久大香线蕉AV| 欧美性猛交xxxx免费看久久久| 久久―日本道色综合久久| 人妻无码中文久久久久专区| 婷婷久久五月天| 日韩十八禁一区二区久久| 精品久久久久久久| 久久99国产综合精品| 久久亚洲AV无码精品色午夜 | 久久精品无码一区二区WWW| 久久久久国产精品麻豆AR影院 | 国内精品久久人妻互换| 亚洲国产精品成人久久| 精品伊人久久大线蕉色首页| 日本加勒比久久精品| 久久精品国产一区二区三区| 国产 亚洲 欧美 另类 久久| 久久91精品综合国产首页| 99久久精品国产综合一区| 国产精品综合久久第一页 | 午夜天堂av天堂久久久| 久久精品国产亚洲AV高清热| A狠狠久久蜜臀婷色中文网| 青青草原综合久久| 久久成人18免费网站|