• <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>

            3d Game Walkman

            3d圖形渲染,網(wǎng)絡(luò)引擎 — tonykee's Blog
            隨筆 - 45, 文章 - 0, 評論 - 309, 引用 - 0
            數(shù)據(jù)加載中……

            游戲資源在線更新的思路

            總的來說,和JIT即時編譯機制有相通之處,就是一個創(chuàng)建時間的比較

             

            首先要明白:客戶端的文件如果是最新的,那么創(chuàng)建時間肯定晚于服務(wù)器上文件的創(chuàng)建時間,反之客戶端的文件就是舊的需要更新了,但是為了提高更新效率,并不是一個個和服務(wù)器上的文件做對比

            而是建立一個文件列表索引文件,里面記錄服務(wù)器上的“最新版”所有文件的創(chuàng)建時間,首先更新本地的索引文件,如果更新了,說明服務(wù)器上的文件列表有更新,然后和本地做對比,整理一份需要更新或新建的文件列表清單,然后主動連接服務(wù)器進(jìn)行下載,全部完成以后,在索引文件進(jìn)行記錄,更新完一個就記錄一個ok,這樣方便“斷點續(xù)傳”,所有都更新完成,全部是ok了,就證明本地都是最新的了,不過這里面有個小問題是值得注意的,本地文件的創(chuàng)建時間不能是本地計算機的時間,應(yīng)該下載完以后,修改成服務(wù)器的當(dāng)前時間,(比如如果本地時間設(shè)置到了一年以前)那本地的列表可能永遠(yuǎn)都是舊的,每次都要更新,這是可怕的。

            通過這個文件列表索引,能大大提高更新效率,而且也能做好版本的控制。

            另外,更新服務(wù)器一般和游戲服務(wù)器分離,大致思路就是這樣

            打包和網(wǎng)絡(luò)傳輸方面,自己封裝一套序列化和反序列化的IO流協(xié)議就可以了,游戲里面這些都必須是最基本的功能了

            當(dāng)然,這套思路還有一些不完善的地方,比如更新正在運行的exe或一些內(nèi)存保護(hù)的DLL,是比較麻煩的事情,需要盡量避免

            posted on 2009-05-08 23:27 李侃 閱讀(2378) 評論(9)  編輯 收藏 引用 所屬分類: 網(wǎng)絡(luò)模塊

            評論

            # re: 游戲資源在線更新的思路  回復(fù)  更多評論   

            本人的思路,不用比較創(chuàng)建的時間,用版本號來比較不是危險性低一些么。每個文件都有一個版本號,更新一次版本號add下。本地一份文件列表(包含文件版本號),更新的時候如你所說,下載一份文件列表(同樣是有版本號的)比較版本來更新。本人的看法,還請斟酌.
            2009-05-09 14:03 | miwei

            # re: 游戲資源在線更新的思路  回復(fù)  更多評論   

            那DLL里面的版本號呢?功能模塊的DLL都是編譯器生成的,你要在每個DLL里面再附加資源信息嗎?我覺得有點繁瑣了。何況如果每個文件都去解析里面的版本號的數(shù)據(jù),速度是會很慢的,不僅繁瑣,而且更難控制。
            不過一些版本控制軟件的卻是加了版本號的,但也是有版本索引文件去記錄這些版本,但絕對沒有要求一定要在源文件中去加版本號。所以時間要素控制版本是高效便宜的做法
            2009-05-09 22:42 | 李侃

            # re: 游戲資源在線更新的思路  回復(fù)  更多評論   

            有點問題:
            如果按照樓主的做法,那么每次更新都需要檢查。目前客戶端資源都是上G的,那么這個操作就會非常耗時。
            而且這么做服務(wù)器的資源必須零散存放。
            但目前資源基本都是打包出現(xiàn)的。

            樓主的這個操作是需要的,只是在客戶端出現(xiàn)資源不完整時候才需要這么做。一般值需要比較版本,下載壓縮包,更新就可以了。
            2009-05-10 13:19 | chib

            # re: 游戲資源在線更新的思路  回復(fù)  更多評論   

            這種方法有點麻煩。。
            倒不如生成一個XML里面寫入各個文件的名稱和md5碼。。
            這樣在讀取下載XML后對比客戶端的XML文件里的MD5就行了。。
            2009-05-10 15:10 | 笨笨狼

            # re: 游戲資源在線更新的思路  回復(fù)  更多評論   

            用客戶機本地的時間是非常不安全的,用戶有可能因為某種原因修改時間。
            笨笨狼同學(xué)的辦法是現(xiàn)在網(wǎng)游大多采用的一種方法。不過需要注意網(wǎng)絡(luò)的緩存問題,最好用FTP服務(wù)器來存放XML文件。
            2009-05-11 09:34 | kevin.c

            # re: 游戲資源在線更新的思路[未登錄]  回復(fù)  更多評論   

            我們的做法:
            做一個更新服務(wù)器,用來匹配資源版本號。
            客戶端每次登陸前都先連接更新服務(wù)器,如果發(fā)現(xiàn)有新的版本,則去文件服務(wù)器(http,ftp服務(wù)器)下載更新包。之后客戶端本地解壓打包就完成了更新。
            2009-05-20 08:39 | christanxw

            # re: 游戲資源在線更新的思路  回復(fù)  更多評論   

            既然客戶端那么大,可以嘗試用P2P 。
            2009-05-22 16:26 | wangok

            # re: 游戲資源在線更新的思路  回復(fù)  更多評論   

            你在樣不太好的。 因為我們以前這樣做過,當(dāng)時打過包后。一個GUI.xx就是40MB 假如想更新一個圖片就要更新40m的包 ,如果詳細(xì)劃分包里面的文件。
            那文件列表就會很大。所以這并不太完美。 最后我也是和 christanxw 的做法一樣了,。
            2009-10-13 17:14 | Johnson

            # re: 游戲資源在線更新的思路  回復(fù)  更多評論   

            如何獲得服務(wù)器上文件的創(chuàng)建時間捏?
            2014-04-29 16:23 | jcjc
            久久se精品一区精品二区| 久久久久久久久久久| 久久国产精品久久| 亚洲国产精品婷婷久久| 九九热久久免费视频| 亚洲国产精品综合久久网络| 久久精品青青草原伊人| 久久人人青草97香蕉| 亚洲一区精品伊人久久伊人| 色欲综合久久躁天天躁| 日本人妻丰满熟妇久久久久久| avtt天堂网久久精品| 久久AAAA片一区二区| 人妻少妇久久中文字幕| 99久久亚洲综合精品网站| 久久久国产99久久国产一| 99久久久精品免费观看国产| 性高朝久久久久久久久久| .精品久久久麻豆国产精品| 日本亚洲色大成网站WWW久久| 精品久久久久久国产潘金莲| 区亚洲欧美一级久久精品亚洲精品成人网久久久久 | 亚洲国产欧美国产综合久久 | 精品综合久久久久久97| 国产A级毛片久久久精品毛片| 亚洲国产精品无码久久98| 人人狠狠综合久久亚洲高清| 国产69精品久久久久99| 久久精品欧美日韩精品| 久久久精品国产sm调教网站| 久久精品免费一区二区| 亚洲国产精品成人AV无码久久综合影院 | 99久久免费国产特黄| 欧美午夜精品久久久久免费视| 久久综合色老色| 欧洲性大片xxxxx久久久| 久久精品亚洲精品国产欧美| 99久久www免费人成精品| 亚洲综合婷婷久久| 国产成人精品久久亚洲高清不卡 | 99久久久精品|