遊戲開發中的資料表示

不會飛的章魚發表於2018-08-06

宣告:本文內容源自騰訊遊戲學院程式公開課_服務端
格式有些亂,在此放置原文連結:https://www.cnblogs.com/OctoptusLian/p/9429351.html

一、資料表示的基礎

什麼是資料表示?
資料是資訊的載體。

資料表示是一組操作,可以描述、顯示、操作資訊。

資料表示的要素
IDL - 介面描述語言

IDL是用來描述軟體元件介面的一種計算機語言。IDL通過一種中立的方式來描述介面,使得在不同平臺上執行的物件和用不同語言編寫的程式可以相互通訊交流;
Data - Operation - 資料操作支援

serialize(序列化)
deserialize(反序列化)
visualize(視覺化)
transform(轉化)
compression(壓縮):資料執行時。

Version Control - 版本控制支援

資料可以有不同版本,且版本間可按照一定規則相容

業界現狀
Google Proto Buffer (Protobuf)
Apache Thrift Binary Protocol
Tencent Data Representation (TDR)
enter image description here

Protobuf In Action
enter image description here

Protobuf具體的使用

通過IDL語言去定義一個.PROTO檔案,然後PROTOBUF會對各個平臺提供PROTO C這麼一個編譯器,然後PROTO C編譯器我們可以指定我要生成對應的C#的DR的表示還是對應的C++的DR表示。

一個學習的機會:編譯一個自己熟悉的語言,比如用PROTOBUF編一個點.c和.cpp檔案出來,它裡面怎麼運算元據的,怎麼壓縮資料的,整個步驟都是可以看到的。

二、資料表示在遊戲開發中的應用

遊戲開發 - 協議(以天刀為例)
互動內容複雜:多重巢狀結構體/二進位制資料。
協議數量巨大:4000+條協議定義;13000+結構體定義。
變更頻繁
網路流量巨大

遊戲開發 - 協議管理
enter image description here

遊戲開發 - 異構系統協議互動
多型別終端協議互動

server:Linux / x86 / C++
client:PC / iPhone / Android;C++ / C# / lua

遊戲開發 - 協議版本相容
enter image description here

遊戲開發 - 協議流量優化
流量優化:通過DR提供的資料壓縮功能進行流量優化。

遊戲開發 - 資料儲存的特點
資料結構複雜:每個玩家的儲存涉及到成千上萬個欄位;
資料結構不穩定:每次版本更新有可能會新增欄位或擴大原有欄位;
update > read > insert > delete。

遊戲開發 - 資料儲存設計
Key - Value資料儲存模型:

Key - 角色ID
Value - 二進位制角色資料
MySQL Blob
使用DR管理Blob資料

資料序列化/反序列化:
資料相容
資料壓縮

enter image description here
我們存檔的時候就是把玩家的資料先serialize成我們的DR描述的中間格式,然後存到DB裡面,DB裡面再讀取出來然後再恢復成我們的runtime格式

三、感受

剛開始概念會介紹的比較多,可能講概念大家比較難以理解,但是做一個東西還是首先要明白基礎概念的定義,後面在基礎概念的定義上進行展開。

相關文章