




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、erlang游戲開(kāi)發(fā)一款social game開(kāi)發(fā)游戲介紹 功能 開(kāi)墾 建造 收租 投資 偷竊 撿取 收費(fèi)點(diǎn)收費(fèi)道具(卡片,特效,場(chǎng)景,自動(dòng)值守)開(kāi)發(fā)語(yǔ)言?我懂erlang所以選擇erlang!開(kāi)發(fā)時(shí)間?sns平臺(tái) 90個(gè)漫漫長(zhǎng)夜$ ls ./include/*.hrl src/*.erl | xargs wc -l . . 6139 總用量$ git shortloglitao (272): initial commit, add protocol.rst add the arch stuff add include and src, compile ok .經(jīng)過(guò)272次提交:6139行代碼
2、(含1500行測(cè)試代碼):選擇mixi平臺(tái)產(chǎn)品現(xiàn)狀 成功的代碼,失敗的產(chǎn)品 缺乏相應(yīng)的運(yùn)維推廣 缺乏用戶數(shù)據(jù)分析 缺乏更多收費(fèi)點(diǎn)的開(kāi)發(fā) 好的產(chǎn)品需要好的團(tuán)隊(duì) 產(chǎn)品 美工 flash server暫忘利益,談?wù)勥^(guò)程。 選擇什么協(xié)議? http amf 自定義選擇http(json): social game實(shí)時(shí)性要求低 http簡(jiǎn)單,成熟 便于調(diào)試使用開(kāi)源的mochiweb mochiwebmochiweb 簡(jiǎn)單輕量高效,將erlang思想貫徹的淋漓盡致,提供了處理http/1.1的基本框架。 需要一些額外工作:將url映射到應(yīng)用空間。 簡(jiǎn)單方案:http:/localhost/who/lita
3、ocheng 對(duì)應(yīng)_http_who_litaocheng.erl,通過(guò)list_to_existing_atom判斷某個(gè)url是否可以處理。交互流程數(shù)據(jù)存儲(chǔ)social game數(shù)據(jù)是核心,數(shù)據(jù)丟失,游戲沒(méi)有了價(jià)值。數(shù)據(jù)要存儲(chǔ)在哪里mysql,mnesia,redis?mysql訪問(wèn)mysql 使用odbc訪問(wèn)mysql,效率較低 第三方driver,如erlang-mysql-driver,不夠成熟,比如無(wú)法處理存儲(chǔ)過(guò)程返回多個(gè)值缺點(diǎn): mysql有些龐大,適合結(jié)構(gòu)化數(shù)據(jù)。social game中的數(shù)據(jù),需要頻繁變化,更像一個(gè)對(duì)象。mnesiaerlang自帶的分布式數(shù)據(jù)庫(kù),與erlang
4、無(wú)縫結(jié)合,擁有很多不錯(cuò)的特性,如分布式,可配置內(nèi)存及磁盤存儲(chǔ),存儲(chǔ)任意erlang term等。缺點(diǎn):數(shù)據(jù)文件大小限制,與其他語(yǔ)言交互不便,效率不是很好。mnesia也是一個(gè)不錯(cuò)的選擇。redis 不僅僅是key-value: string list set zset hash 特點(diǎn) c實(shí)現(xiàn),簡(jiǎn)潔高效 支持多種數(shù)據(jù)持久化存儲(chǔ)方式(aof,dump) 支持vm及replication 將支持clustercache是否需要引入memcached? 多種erlang memcached client需要評(píng)測(cè) redis數(shù)據(jù)放在內(nèi)存中 redis key支持expire因此,redis可以兼具cac
5、he的功能。使用redis作為cache和持久化存儲(chǔ)。 多級(jí)cache 靜態(tài)資源采用nginx,用戶瀏覽器cache 使用erlang process directory,緩存從redis獲取的數(shù)據(jù)(erlang:put/2, erlang:get/1),http connection關(guān)閉,process銷毀,緩存釋放 redis充分利用內(nèi)存,大量數(shù)據(jù)位于內(nèi)存中(類似memcached)使用redis存儲(chǔ)數(shù)據(jù)每個(gè)用戶一個(gè)key: , uid, key對(duì)應(yīng)value為:hash其包含多個(gè)field: “bag”, “bui”, “user”, “msg”, “setting”, “extra”,
6、用來(lái)存放背包,建筑,用戶信息,消息,設(shè)置,額外信息。數(shù)據(jù)通過(guò)erlang的序列化函數(shù)term_to_binary/1轉(zhuǎn)化成二進(jìn)制存儲(chǔ)。 使用hash的原因 減少redis中key的占用 關(guān)系更加緊密的數(shù)據(jù)位于相同的field中 減少數(shù)據(jù)更新量,提高效率 便于擴(kuò)展,增加新屬性時(shí)增加field線上redis運(yùn)行狀態(tài) # redis-cli inforedis_version:1.3.14arch_bits:64multiplexing_api:epolluptime_in_seconds:2299743uptime_in_days:26connected_clients:6used_memory:
7、69993192used_memory_human:66.75mchanges_since_last_save:49533total_connections_received:66total_commands_processed:6373566db0:keys=140638,expires=0引擎運(yùn)行狀態(tài)# ./motownctl status motownlocalhost is running up time:1728104 (20 days) connections: 5查看內(nèi)部狀態(tài):# ./motownctl debug .eshell v5.7.5 (abort with g)(mo
8、townlocalhost)1系統(tǒng)負(fù)載關(guān)于系統(tǒng)容量的思考 單機(jī)支持多少并發(fā)連接? 總的用戶規(guī)模? 單用戶許要數(shù)據(jù)空間大??? 用戶增長(zhǎng)速度? 總的數(shù)據(jù)量? .未來(lái)很難預(yù)測(cè)!數(shù)日的嘗試,結(jié)果徒增苦惱。先實(shí)現(xiàn),后優(yōu)化。舍棄一些想法 不考慮數(shù)據(jù)拆分,丟掉了redis空間劃分的計(jì)劃 不考慮過(guò)高的數(shù)據(jù)可用性,選擇數(shù)據(jù)定期備份,或redis的slave機(jī)制 使用aof sync every second,允許少量數(shù)據(jù)的丟失 不考慮嚴(yán)密的防作弊機(jī)制,簡(jiǎn)單的時(shí)間戳+密鑰的認(rèn)證即可 .放棄換來(lái)輕松,追求完美的路上,需要一些放棄。數(shù)據(jù)管理及統(tǒng)計(jì) 統(tǒng)計(jì)數(shù)據(jù)采用mysql存儲(chǔ),便于其他語(yǔ)言(php,python,jav
9、a)的交互 后臺(tái)管理界面及統(tǒng)計(jì)界面采用php實(shí)現(xiàn) 游戲引擎將統(tǒng)計(jì)信息實(shí)時(shí)保存redis中,定時(shí)(半小時(shí))導(dǎo)出到mysql 引擎定期導(dǎo)入mysql中的物品數(shù)據(jù) mysql, php, redis, erlang各得其所,發(fā)揮各自特長(zhǎng)。測(cè)試 單元測(cè)試: $ make unit_test . all 101 tests passed. 系統(tǒng)測(cè)試:$ make comm_test.testing motown.server: test complete, 20 ok, 0 failed of 20 test casescover analysing.test/log/index.html. donet
10、est/log/all_runs.html. donecommon test輸出服務(wù)器簡(jiǎn)化 數(shù)據(jù)驗(yàn)證 數(shù)據(jù)操作 無(wú)主動(dòng)推送數(shù)據(jù) 如收租:房屋建造后,根據(jù)當(dāng)前時(shí)間(now)及房屋屬性計(jì)算出收租的時(shí)間點(diǎn)(rtime),保存并返回給client。client計(jì)算剩余時(shí)間,開(kāi)始倒計(jì)時(shí),當(dāng)?shù)褂?jì)時(shí)完成時(shí),請(qǐng)求服務(wù)器收租,服務(wù)器判斷rtime now - do_rent(); true - return_failture()end 函數(shù)式編程沒(méi)有面向?qū)ο笃毡?erlang群體較小 erlang涉及概念較多l(xiāng)ua,javascript erlang進(jìn)行框架開(kāi)發(fā) lua或javascript作為輕量的腳本語(yǔ)言,負(fù)責(zé)游戲邏輯處理http:/ http:/ dns輪詢 dns srv(xmpp使用,參考/html/rfc2782) lvs proxy(nginx,haproxy)系統(tǒng)擴(kuò)展數(shù)據(jù):redis
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 水電結(jié)算協(xié)議書(shū)
- 房地產(chǎn)代理商合同
- 室內(nèi)裝修工程勞務(wù)承包協(xié)議書(shū)
- 轉(zhuǎn)讓店鋪及招牌合同協(xié)議
- 配偶出軌協(xié)議書(shū)范本
- 運(yùn)營(yíng)合作協(xié)議合同書(shū)
- 車輛合作經(jīng)營(yíng)合同協(xié)議
- 無(wú)賞修路協(xié)議書(shū)
- 個(gè)人抵押車借款合同
- 超市退換貨合同協(xié)議
- 骨科專業(yè)培訓(xùn)計(jì)劃及總結(jié)
- 鋼結(jié)構(gòu)鋼筋大棚施工方案
- 《春夏中醫(yī)養(yǎng)生》課件
- 機(jī)械通氣患兒的觀察與護(hù)理
- 2021年婦產(chǎn)科主治醫(yī)師資格考試題庫(kù)(含答案)
- 質(zhì)量環(huán)境職業(yè)健康安全管理體系程序文件(終稿)
- 家政服務(wù)行業(yè)的數(shù)字化轉(zhuǎn)型及創(chuàng)新服務(wù)模式研究
- 鎮(zhèn)掃黑除惡培訓(xùn)
- 2024年短劇拍攝及制作協(xié)議版
- IDC基礎(chǔ)知識(shí)培訓(xùn)課件
- 《福建省城鎮(zhèn)道路清掃保潔作業(yè)指導(dǎo)價(jià)》
評(píng)論
0/150
提交評(píng)論