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

            luqingfei@C++

            為中華之崛起而崛起!
            兼聽則明,偏聽則暗。

            一個(gè)簡單的游戲服務(wù)器框架

            http://software.intel.com/zh-cn/blogs/2012/03/22/400010056/?cid=sw:prccsdn2203

            最近一段時(shí)間不是很忙,就寫了一個(gè)自己的游戲服務(wù)器框架雛形,很多地方還不夠完善,但是基本上也算是能夠跑起來了。我先從上層結(jié)構(gòu)說起,一直到實(shí)現(xiàn)細(xì)節(jié)吧,想起什么就寫什么。

            第一部分 服務(wù)器邏輯

            服務(wù)器這邊簡單的分為三個(gè)部分,客戶端的連接首先到達(dá)網(wǎng)關(guān)服務(wù)器,網(wǎng)關(guān)這里有個(gè)線程用來監(jiān)聽來自與客戶端的連接,然后在將這些數(shù)據(jù)發(fā)送到游戲邏輯服務(wù)器上,這個(gè)邏輯游戲服務(wù)器上,數(shù)據(jù)的交互就是通過與數(shù)據(jù)服務(wù)器進(jìn)行交互。RecordServer專門用來處理與數(shù)據(jù)庫的連接,查詢這些事情。當(dāng)然為了游戲服務(wù)器能夠最大程度的不卡,肯定就得規(guī)定好網(wǎng)關(guān)服務(wù)器上的連接數(shù)量,免得像我們號(hào)稱流暢的鐵道部訂票網(wǎng)絡(luò)一樣做個(gè)卡B,想想玩一局dota被卡的悲劇吧。當(dāng)我們要做一個(gè)大型網(wǎng)游時(shí),這三個(gè)服務(wù)器顯然不夠。當(dāng)然在自己寫的小游戲的時(shí)候就無所謂了,幾個(gè)服務(wù)器全部架設(shè)在自己的破筆記本上,不就是啟動(dòng)幾個(gè)程序而已。

            這個(gè)感覺寫得就差不多了,到細(xì)節(jié)吧。

            第二部分 實(shí)現(xiàn)細(xì)節(jié)

            這個(gè)就比較亂了,零零散散的,隨便寫了。這里很多都是對各種工具的封裝,以便于自己 在項(xiàng)目的使用

            1.make

            項(xiàng)目這么多目錄,這么多子目錄,肯定得用工具去編譯了,使用aclocal,automake,autoconf,make,就把我們的程序編譯好了,編寫自己configure.in文件,定義編譯選項(xiàng)、鏈接庫等等一系列亂七八糟的東西,然后對每個(gè)需要編譯的子項(xiàng)目編寫Makefile.am,有的需要要編譯成庫的,比如base等基類這些,其他的都編譯成可執(zhí)行文件了,GatewayServer,LogicalServer,RecordServer。

            2.套接字封裝,epoll使用

            linux里,我們使用socket來讀寫網(wǎng)絡(luò)上的數(shù)據(jù),這個(gè)很簡單了,gateway上一個(gè)客戶端連接過來,我們就為它分配一個(gè)socket 描述符了,在網(wǎng)關(guān)上,一個(gè)線程用來accept,一個(gè)線程用來做數(shù)據(jù)的處理,當(dāng)accept一個(gè)連接請求后,放到數(shù)據(jù)處理的線程,接受到一個(gè)數(shù)據(jù),然后直接轉(zhuǎn)發(fā)到logical server上,我們使用epoll_wait,來處理套接上的讀寫處理。每n ms處理一次循環(huán),每次循環(huán)中使用一次epoll_wait,一次把這些有事件的socket取出來。

            3.數(shù)據(jù)加密解密,壓縮解壓

            對網(wǎng)絡(luò)上的數(shù)據(jù),為了保證安全性,必須對它們進(jìn)行加密解密處理,這個(gè)簡單了,網(wǎng)上各種內(nèi)容,這里就不說了(全部寫完了,有時(shí)間再寫)。對數(shù)據(jù)進(jìn)行壓縮,能減少帶寬吞吐,就是簡單的調(diào)用幾個(gè)zlib函數(shù)的調(diào)用,不細(xì)說,在前面轉(zhuǎn)發(fā)的《zlib使用》中有講,發(fā)現(xiàn)自己太懶,實(shí)在是懶得打字了。

            4.線程封裝,互斥量,讀寫鎖

            這些都是簡單的使用RAII或其他方式,對這些東西進(jìn)行一次本地封裝。(應(yīng)該得寫一個(gè)線程池去管理這些線程,todo)

            5.數(shù)據(jù)庫封裝

            使用mysql,使用mysql的C API函數(shù),這個(gè)必須得封裝一下,不是每次數(shù)據(jù)的處理,都得去做很多事情,實(shí)現(xiàn)一個(gè)本地的數(shù)據(jù)的Field(列),Record(記錄),Table(表),DataBase(數(shù)據(jù)庫),RecordSet(查詢結(jié)果集)。制作一個(gè)數(shù)據(jù)庫連接句柄MysqlHandle,處理對數(shù)據(jù)庫的連接,處理等,實(shí)現(xiàn)一個(gè)HandlerPool,,每次從Pool中取出一個(gè)句柄來對數(shù)據(jù)庫進(jìn)行查詢,免得每次都去重新連接,什么的。

            6.自己的內(nèi)存池

            在之前分享的文章中《內(nèi)存池技術(shù)詳解》《編寫自己的內(nèi)存分配器》,自己的《內(nèi)存池應(yīng)用》,已經(jīng)很詳細(xì)的說明了,內(nèi)存池的制作,當(dāng)然我在這里還是有一些改動(dòng)的,但是大概思路就是這些了。

            7.有一個(gè)狀態(tài)機(jī)的實(shí)現(xiàn)

            這個(gè)也在自己之前寫的那個(gè)狀態(tài)機(jī)相關(guān)的文章里,也做記錄了。哈哈,實(shí)在是不想繼續(xù)碼字了,但是還是堅(jiān)持下去。

            8.lua與c++交互框架

            這個(gè)暫時(shí)寫了一半,等全部完成了,再來弄,反正就是像npc處理這些,腳本處理這些,使用tolua++。

            9.tinyxml封裝,正則表達(dá)式封裝

            tinyxml一個(gè)輕量級的xml解析器,很簡單,反正是把這些現(xiàn)成的東西拿來自己用。正則表達(dá)式?jīng)]有進(jìn)入c++標(biāo)準(zhǔn),但是還是很多現(xiàn)成的正則表達(dá)式的處理,直接用linux庫下的regex.h,就是編譯正則表達(dá)式,匹配結(jié)果這些,

            10.log系統(tǒng)

            一個(gè)項(xiàng)目怎么能沒有自己的日志系統(tǒng)呢,反正就是打日志,往文件里面寫東西,用std::fstream輕松搞定,定義好日志級別:error / debug / fatel / info這些

            11.時(shí)間封裝

            這個(gè)必須有,否則自己還每次去調(diào)用get_clocktime,gmtime,time各種函數(shù)呀。

            12.使用boost庫里的,Noncopyable,Singleton這些設(shè)計(jì)方法,來寫我們的代碼

            13.定義好各種信號(hào)句柄,信號(hào)發(fā)生時(shí)采用什么策略,如SIGPIPE,做忽略處理

            待續(xù)。。。。。。。。(睡覺了)

            游戲服務(wù)器技術(shù)應(yīng)該算來已經(jīng)很成熟了,相比客戶端,它的技術(shù)更新速度很慢了??蛻舳诉@邊,技術(shù)很多,各種游戲引擎比如3D的虛幻這些,什么粒子引擎,聲音這些,頁游的flash, html5,utility,,太多了,搞不過來呀。我先把服務(wù)器這邊好好專專,其他的等以后再說吧。

            posted on 2012-05-29 10:18 luqingfei 閱讀(6174) 評論(0)  編輯 收藏 引用 所屬分類: 游戲開發(fā)

            導(dǎo)航

            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            統(tǒng)計(jì)

            留言簿(6)

            隨筆分類(109)

            隨筆檔案(105)

            Blogers

            Game

            Life

            NodeJs

            Python

            Useful Webs

            大牛

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            評論排行榜

            国产成人精品久久| 狠狠色丁香久久综合婷婷| 久久精品一区二区| 91精品国产91久久综合| 亚洲AV无码久久| 久久久一本精品99久久精品66| 久久久久99这里有精品10| 久久免费看黄a级毛片| 久久久无码精品亚洲日韩蜜臀浪潮 | 国产V综合V亚洲欧美久久| 亚洲AV日韩AV天堂久久| 少妇人妻88久久中文字幕| 77777亚洲午夜久久多喷| 久久久久久久人妻无码中文字幕爆 | 一本久道久久综合狠狠爱| 色综合久久久久久久久五月| 日本强好片久久久久久AAA| 精品久久久久久无码中文字幕一区| 99久久国产热无码精品免费| 久久国产亚洲精品麻豆| 国产精品热久久无码av| yy6080久久| 91精品国产91久久久久福利| 久久久久久A亚洲欧洲AV冫| 久久综合亚洲鲁鲁五月天| 久久精品国产亚洲AV高清热 | 亚洲国产精品无码久久九九| 国产69精品久久久久APP下载| 亚洲AV无码久久精品色欲| 精品午夜久久福利大片| 亚洲综合久久久| 久久久91精品国产一区二区三区 | 久久中文字幕无码专区| 亚洲伊人久久精品影院| 99久久精品费精品国产| 亚洲中文久久精品无码ww16| 久久国产高清字幕中文| 无码八A片人妻少妇久久| 99久久国产亚洲高清观看2024| 欧美激情一区二区久久久| 激情五月综合综合久久69|