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

Creative Commons License
本Blog采用 知識共享署名-非商業性使用-禁止演繹 3.0 Unported許可協議 進行許可。 —— Fox <游戲人生>

游戲人生

游戲人生 != ( 人生 == 游戲 )
站點遷移至:http://www.yulefox.com。請訂閱本博的朋友將RSS修改為http://feeds.feedburner.com/yulefox
posts - 62, comments - 508, trackbacks - 0, articles - 7

游戲腳本變量存取優化

Posted on 2007-12-17 19:55 Fox 閱讀(1568) 評論(5)  編輯 收藏 引用 所屬分類: G游戲編程

Author: Fox

在MMORPG中,存在大量的數據文件和腳本文件,這些文件涉及很多變量,當玩家信息需要存取時(上線、下線、保存、服務器交互),即伴隨著大量的讀寫操作。隨著游戲中游戲任務的增加,每一個玩家對應的需要數據庫存取的腳本變量的數據量也隨之線性增長,隨著玩家數量的增加,在服務器保存玩家角色信息的時候,通信量的大小是相當可觀的,使用多線程讀寫,可以使服務器的處理能力大幅增強,但網絡和數據庫承受的壓力也會大幅增加。

當然現在有很多的腳本語言為我們設計任務系統提供了便利,像Lua、Python、Ruby這些動態語言的功能越來越強,而且可以肯定的是,會有越來越多的產品采用這些優秀的語言。但我今天要談的不是如何使用動態語言,也不是討論動態語言孰優孰劣的問題,而是對于大量的腳本變量的存取優化。說白了,這對于使用自定義腳本語言的游戲開發人員才更有參考價值。而且我要說的問題很小,小到我只是講一點點內容,只是我今天下午的一點活,總結下來更多只是為了讓自己記住,并不是教育別人。

假設在整個腳本系統中,存在500個與玩家相關而且需要數據庫存取的腳本變量,如果一個游戲世界中擁有3000個在線玩家,平均每個玩家的腳本變量大小為10KB,如果服務器同時保存這3000個玩家的數據(那可不僅僅是腳本變量,當然腳本變量所占的分量比較大就是了),3000×10KB,哦……與此同時,服務器還要進行其實正常的網絡通信和邏輯處理(雖然不可能是同一個線程),但服務器承受的壓力已經不小了吧,為了減少這種壓力,腳本變量成為了一種稀缺資源。
為了對腳本變量的存取進行優化,我想到了一個最容易實現的方法。通過對數據庫的觀察(其實想也想也想得到:)),我發現玩家數據中大量的腳本變量的值都是0或者空字符串,這就為優化提供了很大的一個空間。

服務器一般都保存有一個腳本變量的配置文件,在這個文件中列出了所有的腳本變量及其默認值。當玩家登錄時,服務器將為其依據這個文件為其建立一份拷貝,并從數據庫讀取這些變量的真實值填充之。因為大量的變量值都是默認值,所以在往數據庫保存的時候,是沒有必要全部保存的,而只需保存那些不同于默認值的變量名和變量值以及該變量對應的下標即可。下一次從數據庫讀入的時候根據下標確定哪些變量值需要從數據庫中讀取就可以了。

很簡單的一個操作,雖然做到了這一點優化,但是對于500個變量的線性讀取和其他操作,依然不是一個好的處理方法。

幾點改進的方向,目前只是有個想法:

1、將玩家與其腳本變量解耦

并不是所有的玩家都需要500個腳本變量的,不同等級的玩家可以參與的任務和活動是完全不同的,我們顯然沒有必要為每一個玩家從生到死都保持這500個變量。這樣考慮下來,估計一個玩家的腳本變量數可以減少300-400個,從而實現了“垃圾”回收再利用。OMG!

想法是非常具有誘惑力的,但這一優化同時涉及到腳本策劃和程序,而且稍有不慎(對某一變量重復使用),全盤皆輸,在“穩定壓倒一切”的大方針下,這樣的優化需要給出一個系統的策略,玩家等級、職業因素的影響都要考慮進去。

2、對玩家腳本變量實現壓縮存儲

未經壓縮的腳本變量,每個大概有幾十Bytes,如果采用一個好的壓縮算法,能不能減少到10Bytes呢?什么又是一個好的壓縮算法呢?壓縮解壓縮的成本和直接存取成本比起來哪個更高呢?想想這些的確也都是問題呢。

/*****************************************************************************
? 這只是我工作中的一個總結,問題很簡單,也很瑣碎,正如我前面所提的,僅僅是提供一個參考。
*****************************************************************************/

Feedback

# re: 游戲腳本變量存取優化  回復  更多評論   

2007-12-18 09:38 by 金慶
最多總共也只有30M,有必要優化嗎?數據庫性能應該不至于那么低吧?干脆不要存數據庫了,每個用戶一個保存文件就行了,別說30M,30G都沒問題。

# re: 游戲腳本變量存取優化  回復  更多評論   

2007-12-18 09:46 by Fox
把30M放到網絡上跑呢?以現在的網絡質量只怕還做不到,而且邏輯服務器和數據庫服務器往往不在一臺主機上,你所說的方法還是不太可行……

# re: 游戲腳本變量存取優化  回復  更多評論   

2007-12-20 13:50 by 秦歌
能壓縮嗎

# re: 游戲腳本變量存取優化  回復  更多評論   

2007-12-20 14:14 by Fox
其實,網絡消息在傳輸過程中,大多都是經過壓縮的,因此基本沒有再次壓縮的必要和空間里:)

# re: 游戲腳本變量存取優化  回復  更多評論   

2007-12-21 17:52 by Xerxes
將玩家與其腳本變量解耦 確實是個好想法,有時間研究下...
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲综合导航| 亚洲精品久久久久| 欧美一区二区免费观在线| 国产精品国产精品| 欧美一区二区日韩| 欧美在线观看网址综合| 一区二区视频欧美| 91久久精品日日躁夜夜躁欧美 | 国产精品网站在线播放| 午夜精品久久久久久| 午夜精品久久久久久久久久久久久| 国产有码一区二区| 亚洲电影天堂av| 欧美午夜一区二区| 老司机成人网| 欧美日韩成人激情| 久久久高清一区二区三区| 老司机免费视频一区二区三区| 99精品热视频| 欧美在线一二三区| 国产精品99久久久久久人| 亚洲欧美日韩综合| 日韩视频永久免费观看| 亚洲欧美日韩精品久久久| 亚洲日本在线观看| 欧美一区日韩一区| 一区二区三区久久久| 欧美专区第一页| 亚洲一二三区精品| 欧美91大片| 久久精品国产精品亚洲精品| 欧美成人一品| 久久天天躁狠狠躁夜夜爽蜜月| 欧美黄色aa电影| 麻豆精品在线视频| 国产欧美日韩综合精品二区| 91久久精品一区| 尤物精品在线| 午夜一级久久| 亚洲欧美制服中文字幕| 欧美精品一区在线| 欧美黄色aaaa| 黄色亚洲大片免费在线观看| 亚洲天堂网在线观看| 一本久久a久久精品亚洲| 久久婷婷av| 久久一区二区视频| 中文一区在线| 在线亚洲精品福利网址导航| 麻豆精品网站| 欧美99在线视频观看| 国产一二三精品| 亚洲欧美日韩中文播放| 亚洲欧美国产一区二区三区| 欧美另类99xxxxx| 91久久中文| 99国产精品视频免费观看| 麻豆91精品91久久久的内涵| 快播亚洲色图| 亚洲黄色性网站| 麻豆精品一区二区av白丝在线| 卡通动漫国产精品| 亚洲高清视频在线观看| 噜噜噜91成人网| 最新日韩欧美| 亚洲在线第一页| 国产美女扒开尿口久久久| 午夜精品久久久99热福利| 久久大逼视频| 一区在线影院| 免费日韩成人| 夜夜嗨av色综合久久久综合网| 亚洲天堂av图片| 国产精品一区二区久激情瑜伽| 亚洲女人天堂成人av在线| 久久国产精品免费一区| 精品91免费| 欧美黄污视频| 亚洲一区网站| 久久中文欧美| 999亚洲国产精| 国产精品久久久久久久久久免费| 亚洲伊人伊色伊影伊综合网| 久久国产精品久久久| 在线观看91精品国产麻豆| 欧美福利影院| 亚洲一区二区av电影| 久久亚洲精品伦理| 一区二区三区免费网站| 国产精品永久入口久久久| 久久久不卡网国产精品一区| 亚洲高清在线精品| 亚洲欧美一区二区激情| 激情懂色av一区av二区av| 欧美日韩国产成人精品| 亚洲欧美日韩中文视频| 亚洲福利专区| 久久久91精品国产一区二区精品| 亚洲国产色一区| 国产精品视频网| 蜜桃av一区二区三区| 中文欧美字幕免费| 欧美国产综合视频| 午夜国产一区| 亚洲人成在线观看一区二区| 国产精品免费一区豆花| 免费欧美在线视频| 欧美一区免费| 国产精品99久久久久久久久久久久| 久久久亚洲国产美女国产盗摄| 日韩午夜免费| 亚洲大胆美女视频| 国产精品一区二区在线观看不卡| 欧美成人高清| 久久男人资源视频| 午夜欧美大片免费观看| 日韩视频在线观看一区二区| 老司机免费视频一区二区| 性色av一区二区怡红| 亚洲网友自拍| 亚洲麻豆av| 午夜在线观看免费一区| 国产精品无码永久免费888| 欧美韩日一区二区| 久久亚洲一区二区| 午夜日韩电影| 亚洲综合日韩| 亚洲小说欧美另类社区| 日韩写真在线| 亚洲精品资源| 最新成人av网站| 欧美国产日韩a欧美在线观看| 欧美影院精品一区| 欧美亚洲一区在线| 亚洲一区二区三区四区中文| 一本一本大道香蕉久在线精品| 一区三区视频| 亚洲黄色影院| 亚洲免费观看高清在线观看| 亚洲精品国产系列| 亚洲精品美女久久久久| 亚洲精品资源美女情侣酒店| 亚洲国产日韩欧美综合久久| 在线观看视频一区二区| 永久久久久久| 亚洲美女一区| 亚洲先锋成人| 欧美中文字幕| 米奇777超碰欧美日韩亚洲| 欧美777四色影视在线| 欧美激情一区二区三区成人| 亚洲国产精品成人精品| 日韩一级在线观看| 亚洲永久精品国产| 久久成人免费网| 麻豆精品视频在线| 欧美日韩国产一级| 国产精品久久久久久亚洲调教| 国产精品视频免费| 一区二区亚洲欧洲国产日韩| 亚洲黄网站在线观看| 99riav久久精品riav| 亚洲综合三区| 老牛影视一区二区三区| 亚洲黄色有码视频| 亚洲午夜精品久久久久久app| 羞羞答答国产精品www一本| 久久亚洲国产精品一区二区| 欧美连裤袜在线视频| 国产日韩精品视频一区二区三区| 在线日韩av| 亚洲女爱视频在线| 欧美96在线丨欧| 亚洲图片自拍偷拍| 免费欧美电影| 国产目拍亚洲精品99久久精品| 国产综合婷婷| 亚洲一级电影| 欧美电影免费观看网站| 亚洲天堂av高清| 老司机午夜精品视频在线观看| 欧美日韩蜜桃| 亚洲国产高清一区| 欧美怡红院视频| 欧美国产精品va在线观看| 国产精品99久久不卡二区| 久久午夜精品| 国产日韩欧美二区| 亚洲天天影视| 亚洲国产一区二区三区在线播| 亚洲欧美日韩另类精品一区二区三区| 免费久久99精品国产自| 国产三级欧美三级日产三级99| 亚洲卡通欧美制服中文| 久久中文字幕导航| 亚洲欧美日韩中文在线制服| 欧美日韩三级电影在线| 亚洲国产一区二区三区青草影视| 久久精品人人爽| 亚洲欧美日韩精品久久奇米色影视|