手游网络游戏Unity3D帧同步

 帧同步,根据wiki百科的定义是,一种对同步源进行像素级同步显示的处理技术,对于网络上的多个接入者,一个信号将会通过主机同步发送给其他人,并同步显示在各个终端上。同步信号可以是每帧的像素数据,也可以是影响数据变化的关键事件信息。

帧同步在网络游戏中的应用,设计上有异于传统的mmorpg游戏,因为可以承载更大量的后台计算,实现类单机的效果,所以可应用在类似射击类、飞机类中实现弹幕计算或者格斗类的高精度打击体验

本文将主要介绍下帧同步与传统mmorpg设计框架的异同点以及相关的几个设计方案,最后,深入展开对其中一种实现方案的分析,而相关的反外挂和断线重连机制等技术难点暂不在本文讨论。

二、        帧同步在游戏中的应用

网络游戏中,游戏服务的架构大致可以分为2种模式,分别是cs模式和p2p模式

cs模式框架如1(c为客户, GSS为游戏状态服务器)


1,游戏状态服务器(GSS)单独部署,负责对网络上各个接入者提供服务,当GSS状态发生变化时,将状态同步发送给各个接收者。

p2p模式框架如2(c为客户,GSS为游戏状态服务器):


图2中,游戏状态服务器存在于各个客户主机上,游戏状态的改变直接来自于各个客户端的输入。

以上2个服务框架中,cs模式,由于GSS服务器只有一个,游戏状态能保证绝对一致,但GSS可能同时服务上万个玩家,由于机器性能以及网络带宽等硬件资源限制,服务器对大部分情况都无法进行非常严格的检查和处理;p2p模式相对于cs模式,同时连接的玩家有限,所以可以进行比较精细的运算,可实现类似射击类、飞机类的弹幕计算或者格斗类的高精度打击体验,但是,由于端到端的通讯方式,随着同时接入用户的增加,通讯量呈指数级增长,所以,其对同时接入的数量上会限制得比较严格,适合少量同屏的竞技类等游戏。

p2p模式中,由于存在多份的GSS,如何保证各个GSS一致也需要特殊考虑,帧同步算法在游戏中的应用,主要就是为了解决p2p模式下的GSS一致性问题。实现原理是将游戏处理细化为帧,对于每帧,在同样的运行环境中,保证同样的输入的情况下,将得到同样的输出结果。

图3中,初始状态都为1,序列帧第二帧时,输入加1操作,则状态变为2,第三帧时无输入,状态不变,第四帧时,输入加1操作,状态变为3.对于同个运行环境的各个客户端来说,相同的输入状况下,将得到相关的输出结果,如4效果。


通常,为了用户的输入能及时的响应以及游戏状态的过度能够平滑,会将GSS设置为20到30帧以上。并且,由于客户端机器性能或者设置的差异,GSS的状态无法与游戏渲染帧实现一一对应,所以,GSS与表现层必须做到完全的分离,否则将因为某些细小的误差被放大最终导致游戏出现完全不同的结果。


5,非确定的渲染层的输出,完全由GSS来驱动,GSS保证帧数的稳定,即使出现网络延迟,也必须在确保收到该帧的所有输入后才执行该帧的处理。

实现方案上,大致可以分出3种,分别是无主机结构、有主机结构、服务器主机结构

u无主机结构

2的拓扑结构中,所有GSS功能对等,该方案需要进行特殊的对帧处理,确保所有客户端都已经同步并且收到所有的输入。但是,由于网络上的各个客户端完全对等,一旦某个用户网络状况出现延迟或者中断等异常,将影响其他用户的操作体验,所以该方案简单公平但体验容易受限


u有主机结构


6,在各个客户端中随机选择一个的GSS作为主机,同时负责对帧控制及输入输出管理,其他GSS仅跟GSS主机通讯,GSS之间互相不通讯。该方案的好处是,游戏的体验只受主机与本机的网络与本机器状况的影响,其他GSS出现的任何故障都不会影响其他人,当GSS主机完全失去联系时,其他GSS也可以重新仲裁得出新的GSS主机来,但该结构主机在客户端,容易给外挂有可乘之机,对输入对帧等能进行特殊处理,最终导致游戏丧失公平性。此方案能保证玩家体验,但安全性较低

u服务器主机结构

服务器主机结构,是将6的结构中的GSS主机的的对帧控制及输入输出管理功能放在服务器上,降低GSS客户端的客观影响,保证了大部分玩家的体验,且其中有玩家作弊,也能马上检测到,保证游戏的公平性,但结构上已脱离p2p设计,通讯流量随用户增加,负额指数级增长。该方案安全性高,保证玩家体验,但对服务负载有一定的要求。

u其他

融合有/无主机与服务器主机的结构。服务器主机结构的特点在于控制权在服务端,在有状态的网络游戏中,可以有效防止游戏数据修改、游戏加速等外挂,在服务端硬件资源方面,可以增加有/无主机结构减轻负担,大部分功能用有/无主机结构处理,关键操作由服务器主机结构处理等,让GSS主机与服务器主机协同服务


三、        服务器主机结构设计

服务器主机结构的特点如上所述,这里再深入展开对该结构的分析与设计。

服务器设计

图7


服务器主要是起到控制作用,进行客户端的对帧控制和输入输出管理。如7,服务器每帧都发驱动帧驱动客户端执行帧处理,当客户端有输入被服务器接收到,则服务器当前帧内将输入同步输出给各个客户端.

网络上由于客户端的状况多种多样,客户端帧数可能跟不上服务器,如8所示,如果客户端出现掉帧情况,则在收到驱动帧后需要加速执行,以追上其他客户端的速度,避免掉帧的用户一直在对过去的事件进行响应。

游戏应该优先保证正常用户的体验,所以当有玩家出现卡帧情况的时候,不应选择暂停其他玩家,而是让他慢慢的追赶上来,设计上,服务器即可以采用客户端的正常速度,按帧驱动客户端,但当网络都出现突发状况的时候,如9,通讯异常时,2个客户端都对帧数2缺失,如果服务器照常运行,到恢复网络状况时,会出现情况是,每个客户端都卡了几帧之后,加速拉了几帧。所以,针对这种情况,增加客户端的对帧操作,即客户端执行第1帧时,跟服务器说可以播放第二帧了,然后服务器开始驱动第二帧动作,考虑网络延迟情况,可以提前对帧第n帧的,效果如9,左边客户端第二个对帧操作使服务器开始推动第二帧进行,而右边客户端的第二个对帧动作其实不起任何作用

图8

图9

客户端设计


客户端设计由两部分组成,分别是GSS模块和渲染模块。

GSS模块包含物品系统、角色系统、AI系统、场景系统还有其他相关系统等,同时,输入输出和帧数控制也一起集成在GSS模块中。GSS中各系统功能分别是:

         物品系统:       游戏物品以及物品的效果

         角色系统:       角色包括玩家角色、npc及apc等

         ai系统:          驱动apc行动的控制模块

         场景系统:     场景物件、地图、寻路等

         其他系统:      其他类似技能、状态等系统

         输入输出模块:       监听玩家输入,将玩家输入上报服务器,同时监听服务器输入,绑定当前帧输出

         帧数控制模块:      监听服务器驱动帧,驱动执行每帧处理

GSS模块中各个系统的执行,由帧数驱动,不引入其他时间线。有如物品持续时间、状态持续时间等都以帧数作为唯一的时间轴。帧与帧之间的播放频率,则由服务器统一控制,但由于网络抖动等影响,帧的频率并不是太稳定,为避免播放抖动,帧数控制器需要进行一定的平滑处理。


客户端的渲染层,由GSS模块驱动,为减少模块间的耦合,GSS模块使用事件通知机制驱动渲染层表现。具体细分事件类型如12(具体项目具体事件拆解)


由于渲染层与GSS只做到事务级的同步,而GSS与渲染层的播放速率有可能不同,则为保证较好的表现效果,GSS的逻辑帧需要与渲染层的渲染帧做固定比率的绑定,譬如13的1:2,当GSS逻辑帧数不变的情况下,渲染帧掉帧时,能经过换算得到当前逻辑帧对应的渲染帧数,出现GSS帧数暂停时,则逻辑帧也跟着一起暂停

其中  OnUpdate由引擎在每帧调用,GetNewestFrame获得逻辑帧通知过来的最新帧,这样,保证了逻辑帧中关键帧进行伤害计算时,渲染帧不会脱帧严重。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,294评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,780评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,001评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,593评论 1 289
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,687评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,679评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,667评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,426评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,872评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,180评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,346评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,019评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,658评论 3 323
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,268评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,495评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,275评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,207评论 2 352

推荐阅读更多精彩内容