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

淺談?dòng)螒蚍?wù)器-》架構(gòu)上來(lái)看(三)

老手拍磚 新手看  轉(zhuǎn)載注明http://www.shnenglu.com/ziyebuboka/
     本文介紹一下一個(gè)應(yīng)用的游戲服務(wù)器的架構(gòu)和演變
      游戲服務(wù)器的作用在于滿足在線玩家的需求,實(shí)現(xiàn)賬號(hào)的驗(yàn)證,登陸,玩家在游戲世界的一系列邏輯操作和驗(yàn)證。在此基礎(chǔ)上,一個(gè)好的架構(gòu),可以提升效率,在實(shí)現(xiàn)邏輯需求的情況下達(dá)到百萬(wàn)級(jí)的同時(shí)在線數(shù)也不是不可能。
      我們先從最搓的最簡(jiǎn)單的結(jié)構(gòu)看起
      
      CLIENT ----------  SERVER   ---------   DBSYSTEM

      就是一個(gè)很簡(jiǎn)單的 C/S系統(tǒng)  同一個(gè)server同時(shí)處理登陸注冊(cè)創(chuàng)建角色和游戲邏輯操作的功能,。在server上直接掛接DB操作。DB可以是一個(gè)具體的數(shù)據(jù)庫(kù)也可以是一個(gè)FILESYSTEM
      這里可以看的出來(lái),過(guò)于簡(jiǎn)單了,將登陸注冊(cè)創(chuàng)建和具體邏輯這幾個(gè)毫無(wú)關(guān)系的東西放置于一起,嚴(yán)重?fù)p耗了具體邏輯操作的效率,特別是在新開服階段,完全會(huì)因?yàn)榈顷戲?yàn)證的操作而導(dǎo)致邏輯爆卡。
      所以這里需要升級(jí),將完全不同類型在玩家一次游戲操作工程中只會(huì)在登陸階段執(zhí)行一次的操作單獨(dú)分開,單獨(dú)進(jìn)程解決,。故而可成為下面階段
       
                 -  LOGINSERVER -
               -                                 -
CLIENT -                                   -  DBSYSTEM
               -                                -
                - GAMESERVER -

分為兩個(gè)服務(wù)器,這個(gè)我在一文章里的開頭就有提到過(guò)了。

我們來(lái)看下好處進(jìn)階,在LOGINSERVER里只執(zhí)行賬號(hào)驗(yàn)證  查詢角色列表  創(chuàng)建角色的操作   而后玩家登陸進(jìn)GAMESERVER  具體邏輯操作在GAMESERVER里完成

玩家的一次登陸操作

                   發(fā)送賬號(hào)                                 驗(yàn)證                               返回角色列表                          創(chuàng)建角色
CLIENT---------------LOGINSERVER -----------DBSYSTEM-----------------------CLIENT ------------------
                                                                                                選擇角色與LOGIN斷鏈與GAME連接 登陸
LOGINSERVER -------DBSYSTEM  ----------CLIENT  ------------------------------------------------------GAMESERVER

如此,可有效的提升效率,玩家的驗(yàn)證 列表讀取 創(chuàng)建 和GAME就毫無(wú)關(guān)系了,但是他的缺點(diǎn)任然存在 我們?cè)倮^續(xù)看可優(yōu)化的地方

首先從數(shù)據(jù)庫(kù)上來(lái)提升效率(先說(shuō)下,從這里開始就應(yīng)該是肯定的是用數(shù)據(jù)庫(kù)了,而非什么本地FILE了,),將賬號(hào)庫(kù)和游戲數(shù)據(jù)庫(kù)分開,分離為兩個(gè)獨(dú)立的庫(kù),
具體理由有兩個(gè):
1:從游戲運(yùn)營(yíng)上來(lái)說(shuō) 你不可能一直是只有一個(gè)服吧? 分成多個(gè)服后 人數(shù)越來(lái)越多,就不能所有服都共用一個(gè)數(shù)據(jù)庫(kù)了吧?那你這數(shù)據(jù)庫(kù)也牛逼了
      所以我們這里這么干,將 賬號(hào)庫(kù)獨(dú)立,全游戲共用,這樣是方便管理,方便管理賬號(hào)的全局性的信息 經(jīng)濟(jì)性的 比如點(diǎn)卡什么的,每個(gè)服一個(gè)游戲數(shù)據(jù)庫(kù),只記錄操作你這個(gè)服的玩家信息,世界信息。
2:理由類同將服務(wù)器拆分為L(zhǎng)OGIN和GAME。

現(xiàn)在 結(jié)構(gòu)就是這樣的

                   - LOGINSERVER-
                 -                               - ACCOUNTDBSYSTEM
 CLIENT -                                                             -   
                 -                               - GAMEDBSYSTEM 
                   - GAMESERVER -


但是到了這里后 肯定還是不夠的,
我們先說(shuō)個(gè)基本的,在服務(wù)器里 ,你一定要記得,數(shù)據(jù)庫(kù)操作,IO操作 ,文本操作這些 一定要單獨(dú)進(jìn)程不要和主進(jìn)程搞一起,你總不希望你做了個(gè)什么查詢還是什么操作 他主線程掛起吧?但是,試想下,如果能單獨(dú)進(jìn)程肯定還是單獨(dú)進(jìn)程更爽一點(diǎn)吧?你還能在里面做做緩存啥的,還不占服務(wù)器的資源
    所以這里還是麻煩的 從效率上來(lái)說(shuō) 至少后臺(tái)這塊 還有很大提升空間。因此,我們加入 DBAGENT模塊 ,單獨(dú)進(jìn)程,將數(shù)據(jù)庫(kù)操作單獨(dú)分離,并且可自我添加某些應(yīng)用的緩存

對(duì)應(yīng)ACCOUNTDBSYSTEM 增加 accountagent ,對(duì)應(yīng) GAMEDBSYSTEM 增加 gameagent

結(jié)構(gòu)如下


                 -LOGINSERVER-
               -                              - accountagent - ACCOUNTDBSYSTEM
CLIENT -                                                                                                   
               -                              - gameagent   - GAMEDBSYSTEM 
                -GAMESERVER -

LOGINSERVER同時(shí)和accountagent和gameagent連接   gameserver也同時(shí)和這兩個(gè)連接   服務(wù)器通過(guò)agent來(lái)對(duì)對(duì)應(yīng)的數(shù)據(jù)庫(kù)做操作   因?yàn)閍ccountdbsystem可能是全服共有的 ,所以accountagent也可以是全服共有的 他連接所有的服務(wù)器。loginserver通過(guò)accountagent來(lái)驗(yàn)證 通過(guò)gameagent來(lái)查詢列表 創(chuàng)建角色  gameserver通過(guò)gameagent來(lái)查詢完整角色信息登陸進(jìn)game,并通知accountagent此賬號(hào)已進(jìn)入游戲,避免重復(fù)登陸。并且定期保存。設(shè)置你可以將比如你游戲的排行榜啊,拍賣行啊的信息放置于你自己設(shè)計(jì)的gameagent的緩存中,而避免重復(fù)查詢

玩家每一個(gè)對(duì)數(shù)據(jù)庫(kù)的操作 server只需發(fā)送消息到agent agent來(lái)做具體操作,而后再返回到server 再到client就可。將數(shù)據(jù)操作完全的異步操作,效率有較大提升。并且安全性上也得到了些許保證。

不是我胡說(shuō)或者輕視,國(guó)內(nèi)一大半游戲,都用的上面這個(gè)結(jié)構(gòu)。。。。。。。。。。。。。。。。。。。。。這個(gè)可以算是一個(gè)比較完善的產(chǎn)品化架構(gòu)了。

說(shuō)到這里,大家有沒(méi)有發(fā)現(xiàn)一個(gè)共性。采用這類架構(gòu),游戲必然會(huì)是先選服務(wù)器再驗(yàn)證賬號(hào) 登陸進(jìn)游戲,這是因?yàn)榉?wù)端采用的是LOGIN和GAME一對(duì)一得處理,也就是你是登陸的什么服務(wù)器必然就是從什么服務(wù)器的LOGIN進(jìn)入驗(yàn)證,故而他需要在客戶端開啟的時(shí)候就要知道需要連接的是哪個(gè)LOGIN 賬號(hào)驗(yàn)證成功后再是哪個(gè)GAME
其實(shí)這里很好處理,就在客戶端上做些處理就可以達(dá)到先登陸驗(yàn)證在選服務(wù)器。所以在配置上 LOGIN不再是一對(duì)一(后面會(huì)有優(yōu)化的再說(shuō)到多個(gè)LOGIN),全局也共用一個(gè)LOGIN。玩家開啟客戶端,連接LOGIN。發(fā)送賬號(hào)驗(yàn)證。因?yàn)檫@里已經(jīng)是把ACCOUNTDBSYSTEM做成全局的了,所以是不用擔(dān)心他是哪個(gè)服的,然后返回成功,玩家客戶端顯示服務(wù)器列表(這個(gè)列表還有連接信息配置再客戶端就可以了)選擇某一個(gè)服后,則發(fā)送查詢某服角色列表的請(qǐng)求到LOGIN,而后再返回再登陸游戲就可。小小調(diào)整和改變就可實(shí)現(xiàn)先驗(yàn)證后選服務(wù)器了。

      所以,到了這步,服務(wù)器架構(gòu)就變成這個(gè)樣子了


                  -LOGINSERVER-
                -                               - accountagent -ACCOUNTDBSYSTEM
CLIENT -                                 |--------                                           
                -                                |-----------
                 - 
                  - GAMESERVER  - gameagent     -GAMEDBSYSTEM 
                    -                                             |  
                   - GAMESERVER  -gameagent      -GAMEDBSYSTEM 

全局共用一個(gè)LOGIN和一個(gè)ACCOUNTAGENT還有ACCOUNTDBSYSTEM
每個(gè)獨(dú)立服各自獨(dú)立的gameagent 和gamesdbystem
但是LOGIN的瓶頸立馬出現(xiàn)了,當(dāng)初是一個(gè)服獨(dú)立一個(gè)LOGINSERVER 現(xiàn)在是全服只有一個(gè)了,毫無(wú)以為,扛不住。

其實(shí)上面這個(gè)架構(gòu)的不一定非得存在的,就是隨便寫寫,讓大家更清楚一點(diǎn)。

所以LOGINSERVER就得配置多個(gè)了。這個(gè)地方大家選擇吧 盡量靈活點(diǎn),可以全服單位的配置多個(gè)也可以每個(gè)服對(duì)應(yīng)的配置多個(gè)LOGINSERVER。這樣 在開服時(shí)候,這種大面積井噴式的玩家玩家上線,可有效解決負(fù)載。具體CLIENT開啟后會(huì)是和哪個(gè)LOGIN連接呢
這里提供兩種方式。一個(gè)是配置上的 一個(gè)是程序上的
1:
   程序上的好說(shuō) ,你把所有LOGINSERVER的連接信息都配置到客戶端,讓客戶端開啟后隨機(jī)選擇一個(gè)去連接。要是你開服后,他所有玩家都隨機(jī)到一個(gè)LOGINSERVER了,那真的算你點(diǎn)背。背到家了
2:配置上 :
   通過(guò)基于DNS的負(fù)載均衡系統(tǒng),DNS中為一個(gè)域名配置多個(gè)IP地址。通過(guò)負(fù)載,讓系統(tǒng)來(lái)選擇是對(duì)應(yīng)到哪個(gè)IP

所以就是     
                 -LOGINSERVER   -|

                 - LOGINSERVER  -|

                 -LOGINSERVER   -|
                -                  -accountagent -ACCOUNTDBSYSTEM
CLIENT -                                  |--------                                           
                -                                 |-----------
                - 
                -GAMESERVER -gameagent   -GAMEDBSYSTEM 
                -                                             |  
                -GAMESERVER - gameagent  -GAMEDBSYSTEM 

或者是:

        

        - LOGINSERVER   -             
         - LOGINSERVER   -   
         - LOGINSERVER   - 
      ..................................上面可以是N個(gè)                                                                             
        -                                -gameagent -GAMEDBSYSTEM 
        -GAMESERVER  -

Client
       - LOGINSERVER   -      
         - LOGINSERVER   -   
         - LOGINSERVER   - 
      ..................................上面可以是N個(gè)                                                                                            
                                         - gameagent-GAMEDBSYSTEM 
        - GAMESERVER  -

  accountagent    --              --- ACCOUNTDBSYSTEM 是全局的

一個(gè)服對(duì)應(yīng)好多個(gè)LOGINSERVER


因?yàn)長(zhǎng)OGINSERVER使用的動(dòng)態(tài)配置,故而可在登陸下線沒(méi)有多大壓力的情況下,關(guān)掉幾個(gè)LOGINSERVER,節(jié)省運(yùn)維資源


不想寫了,元旦又混了三天,明天繼續(xù)吧。明天把前面的再擴(kuò)展下,再說(shuō)下分線的和分布的。牛逼的就不說(shuō)了
     http://www.shnenglu.com/ziyebuboka/

posted on 2010-01-04 00:35 ziyebuboka 閱讀(3459) 評(píng)論(14)  編輯 收藏 引用 所屬分類: 游戲服務(wù)器

評(píng)論

# re: 淺談?dòng)螒蚍?wù)器-》架構(gòu)上來(lái)看(三) 2010-01-04 01:04 jigloo

啊,深夜也發(fā)文啊。一直在關(guān)注!  回復(fù)  更多評(píng)論   

# re: 淺談?dòng)螒蚍?wù)器-》架構(gòu)上來(lái)看(三) 2010-01-04 01:08 ziyebuboka

一到晚上就精神了、、、、、、、不到個(gè)幾點(diǎn)睡不著啊  回復(fù)  更多評(píng)論   

# re: 淺談?dòng)螒蚍?wù)器-》架構(gòu)上來(lái)看(三) 2010-01-04 09:16 Pencil.C++

看帖要回帖!  回復(fù)  更多評(píng)論   

# re: 淺談?dòng)螒蚍?wù)器-》架構(gòu)上來(lái)看(三) 2010-01-04 10:56 blocker

一直在關(guān)注。繼續(xù)繼續(xù)!  回復(fù)  更多評(píng)論   

# re: 淺談?dòng)螒蚍?wù)器-》架構(gòu)上來(lái)看(三) 2010-01-04 11:07 blocker

cppblog牛B人是多  回復(fù)  更多評(píng)論   

# re: 淺談?dòng)螒蚍?wù)器-》架構(gòu)上來(lái)看(三) 2010-01-04 12:46 ziyebuboka

。。。。。。。。。。。。。。。。。。。  回復(fù)  更多評(píng)論   

# re: 淺談?dòng)螒蚍?wù)器-》架構(gòu)上來(lái)看(三) 2010-01-04 12:47 billow

LZ繼續(xù)啊,等著看呢,畫圖的部分建議下面用圖畫好了再傳上來(lái),這樣畫的圖都混亂了。  回復(fù)  更多評(píng)論   

# re: 淺談?dòng)螒蚍?wù)器-》架構(gòu)上來(lái)看(三) 2010-01-04 12:53 ziyebuboka

BLOG玩的不熟,其實(shí)這方面我OUT了。。。。晚上研究下。。。。。。。俺本來(lái)是準(zhǔn)備畫圖的,然后一打字就顯麻煩就直接打字畫了。。然后還自認(rèn)為格式弄的很好,而后發(fā)出來(lái)成這樣了。。。。。。  回復(fù)  更多評(píng)論   

# re: 淺談?dòng)螒蚍?wù)器-》架構(gòu)上來(lái)看(三) 2010-01-05 08:45 direct

寫的不錯(cuò),很真實(shí)  回復(fù)  更多評(píng)論   

# re: 淺談?dòng)螒蚍?wù)器-》架構(gòu)上來(lái)看(三) 2010-01-05 17:52 陳昱(CY)

關(guān)注中....  回復(fù)  更多評(píng)論   

# re: 淺談?dòng)螒蚍?wù)器-》架構(gòu)上來(lái)看(三) 2010-01-05 19:20 zctong

繼續(xù)關(guān)注中  回復(fù)  更多評(píng)論   

# re: 淺談?dòng)螒蚍?wù)器-》架構(gòu)上來(lái)看(三) 2010-01-06 17:16 Monokeros

不錯(cuò)啊,很有意思的文章,繼續(xù)加油!如果這樣的文章早點(diǎn)出現(xiàn)的話,我就不用走之前那些彎路了。光尋路就惡心死,不過(guò)我沒(méi)用A*,最后圖省事,用的光線追蹤。嘎嘎~  回復(fù)  更多評(píng)論   

# re: 淺談?dòng)螒蚍?wù)器-》架構(gòu)上來(lái)看(三) 2010-01-06 19:16 ziyebuboka

A*是最垃圾的,實(shí)際開發(fā)中肯定不會(huì)用了 哈  回復(fù)  更多評(píng)論   

# re: 淺談?dòng)螒蚍?wù)器-》架構(gòu)上來(lái)看(三) [未登錄](méi) 2010-02-02 14:11 cppexplore

剛頂錯(cuò)地方了 呵呵. 好文! 期待博主繼續(xù)  回復(fù)  更多評(píng)論   

導(dǎo)航

<2010年4月>
28293031123
45678910
11121314151617
18192021222324
2526272829301
2345678

統(tǒng)計(jì)

常用鏈接

留言簿(2)

隨筆分類

隨筆檔案

搜索

最新評(píng)論

閱讀排行榜

評(píng)論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲男人第一网站| 欧美性色综合| 亚洲精品一区久久久久久| 9色porny自拍视频一区二区| 欧美人与性动交cc0o| 一区二区三区久久网| 久久国产视频网站| 亚洲第一久久影院| 欧美日韩一区二区三区在线观看免| 99视频一区二区| 久久精品一区蜜桃臀影院| 亚洲成色www8888| 欧美日本在线| 欧美一区二区在线看| 欧美激情视频一区二区三区免费| 一区二区三区产品免费精品久久75| 国产精品美女久久| 榴莲视频成人在线观看| 一区二区三区高清视频在线观看| 久久精品视频亚洲| 亚洲伦理在线| 国产亚洲永久域名| 欧美精品自拍| 欧美专区福利在线| 亚洲日韩第九十九页| 性色一区二区| 日韩性生活视频| 狠狠爱成人网| 国产精品成人在线| 免费短视频成人日韩| 亚洲综合日韩在线| 亚洲人妖在线| 女生裸体视频一区二区三区| 亚洲伊人伊色伊影伊综合网 | 亚洲免费影视第一页| 伊人久久噜噜噜躁狠狠躁| 欧美日韩亚洲另类| 六月婷婷一区| 欧美在线欧美在线| 中文在线资源观看网站视频免费不卡 | 99热这里只有精品8| 国产亚洲一本大道中文在线| 欧美日韩国产首页在线观看| 久久久精品999| 亚洲欧美日韩直播| 一区二区三区四区五区视频| 欧美国产日韩精品免费观看| 久久精品论坛| 欧美一区二区播放| 亚洲性色视频| 一区二区三区精品在线| 亚洲国产美女| 在线免费观看一区二区三区| 国产精品自拍在线| 国产精品久久久久久久午夜片| 欧美精品一区二区精品网| 久久中文字幕一区| 久久久www免费人成黑人精品| 午夜精品在线视频| 亚洲一区二区三区777| 国产精品99久久久久久久久久久久| 亚洲激情影视| 亚洲日本成人| 亚洲国产专区| 亚洲精品网站在线播放gif| 亚洲福利小视频| 亚洲激情在线观看| 亚洲三级色网| 日韩视频免费看| 一本色道久久综合亚洲精品不| 亚洲人成在线观看一区二区| 亚洲三级观看| 一区二区黄色| 亚洲一区二区三区在线视频| 亚洲影院免费| 欧美一区二区三区男人的天堂 | 欧美mv日韩mv国产网站| 美国成人毛片| 欧美黄色免费| 亚洲精品乱码久久久久久按摩观| 亚洲日本在线观看| 亚洲视频在线观看视频| 亚洲永久字幕| 欧美在线在线| 老司机精品视频网站| 欧美成ee人免费视频| 欧美精品免费在线观看| 欧美系列一区| 国产亚洲欧美日韩在线一区| 一区三区视频| 亚洲乱码国产乱码精品精98午夜| 亚洲视频在线观看三级| 亚洲欧美久久久久一区二区三区| 欧美在线免费看| 浪潮色综合久久天堂| 91久久久在线| 亚洲一区在线观看视频| 久久久免费av| 欧美日本免费| 国产婷婷色一区二区三区四区 | 久久一日本道色综合久久| 欧美777四色影视在线| 亚洲乱码国产乱码精品精| 亚洲桃色在线一区| 久久综合狠狠综合久久综青草| 欧美激情一级片一区二区| 国产精品中文字幕在线观看| 一区二区三区在线观看欧美| 一本综合精品| 久久综合九色综合网站| 亚洲精品中文字幕女同| 久久国产88| 欧美日韩亚洲一区三区| 好吊色欧美一区二区三区视频| 日韩视频一区| 久久久久一区二区三区| 亚洲日韩中文字幕在线播放| 欧美尤物一区| 欧美午夜一区二区| 亚洲高清中文字幕| 欧美一区二区大片| 亚洲日本视频| 久久久久国产成人精品亚洲午夜| 欧美日韩一区视频| 亚洲电影在线看| 亚洲欧美日韩国产中文在线| 亚洲高清色综合| 先锋资源久久| 国产精品美女www爽爽爽| 亚洲精品在线免费| 久久亚洲私人国产精品va媚药| 一区二区三区精品视频| 嫩草影视亚洲| 在线日韩中文字幕| 欧美主播一区二区三区美女 久久精品人| 亚洲电影激情视频网站| 久久精品国产免费看久久精品| 欧美午夜精品一区| 夜夜狂射影院欧美极品| 欧美电影电视剧在线观看| 久久成人亚洲| 国产欧美精品一区二区三区介绍 | 午夜精品国产| 国产精品mm| 亚洲深夜福利网站| 亚洲激情另类| 欧美成ee人免费视频| 亚洲高清二区| 女同性一区二区三区人了人一 | 99精品国产福利在线观看免费 | 一区二区在线观看视频在线观看 | 能在线观看的日韩av| 激情欧美日韩一区| 久久久久一本一区二区青青蜜月| 亚洲综合色视频| 国产伦精品一区二区三区免费| 亚洲欧美日韩精品久久| 一本色道久久综合亚洲精品按摩 | 国产精品乱码一区二区三区| 亚洲私拍自拍| 亚洲一区二区av电影| 国产精品外国| 久久九九国产精品怡红院| 性欧美暴力猛交另类hd| 国产视频一区在线观看| 欧美在线观看网站| 欧美一区二区三区四区视频| 国产一区二区无遮挡| 久久久久这里只有精品| 久久久久久久久久久久久久一区| 在线国产欧美| 亚洲国产精品久久人人爱蜜臀| 欧美大片91| 亚洲网站视频福利| 亚洲综合色在线| 国内成人在线| 欧美电影在线观看完整版| 欧美国产一区视频在线观看| 9久re热视频在线精品| 亚洲无人区一区| 国产日本欧洲亚洲| 欧美a级理论片| 欧美精品乱人伦久久久久久| 亚洲综合日韩在线| 欧美在线观看网站| 亚洲精品久久在线| 99精品视频免费全部在线| 国产农村妇女毛片精品久久莱园子| 久久久精品tv| 欧美交受高潮1| 亚洲欧美制服另类日韩| 欧美中文字幕在线观看| 亚洲美女黄网| 亚洲一区欧美一区| 亚洲国产cao| 中日韩高清电影网| 在线观看三级视频欧美| 夜夜精品视频| 一区二区在线视频播放| 一区二区高清在线观看|