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

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

            <2025年8月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            常用鏈接

            留言簿(2)

            隨筆分類

            隨筆檔案

            文章分類

            文章檔案

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            久久99国产精品久久99| 久久亚洲天堂| 久久99国产精品尤物| www.久久热| 欧美无乱码久久久免费午夜一区二区三区中文字幕 | 久久精品免费大片国产大片| 亚洲国产成人精品无码久久久久久综合| 中文字幕久久亚洲一区| 久久精品国产亚洲AV无码麻豆| 精品久久久久久国产| 伊人久久国产免费观看视频| 久久99精品久久久久婷婷| 欧美久久亚洲精品| 亚洲天堂久久精品| 无码人妻少妇久久中文字幕蜜桃 | 蜜臀av性久久久久蜜臀aⅴ| 国产午夜福利精品久久| 久久天天躁狠狠躁夜夜2020一 | 天天久久狠狠色综合| 久久久久久亚洲精品影院| 久久精品国产99久久久| 久久人人爽人人爽人人片AV高清 | 影音先锋女人AV鲁色资源网久久 | 色欲综合久久中文字幕网| 久久久久久国产精品美女| 久久99精品国产99久久6男男| 成人久久免费网站| 亚洲国产成人久久综合碰| 93精91精品国产综合久久香蕉| 久久天天躁狠狠躁夜夜96流白浆| 狠狠色丁香久久婷婷综合图片| 久久精品女人天堂AV麻| 久久国产成人午夜aⅴ影院| 99国产精品久久久久久久成人热| 人妻精品久久无码区| 丰满少妇人妻久久久久久 | 色欲综合久久躁天天躁| 久久涩综合| 久久久久久久免费视频| 久久久久久久91精品免费观看| 久久综合亚洲色一区二区三区|