您现在的位置: 主页 > 游戏研发 > 游戏程序 >

网游的跨服玩法是如何实现的?“跨域体系”架

  虽然游戏市场竞争激烈,产品格局变动较大,但游戏产业一直处于稳步增长阶段,无论是在端游,页游,手游还是已经初露端倪的HTML5游戏。可以预见,游戏类型中,MMOARPG游戏仍然会是引领市场的主流趋势,贡献着大部分流水,市场上也仍然在不断涌现精品。研发团队对MMO游戏的探索从来未间断过,从付费模式的改变,到题材多元化,次时代的视觉效果,更成熟的玩法及数值体系,本文主要针对跨服玩法上的探索和实现做一些思考和分析。

  根据2016年《中国游戏产业报告》数据显示,随着游戏人口红利逐渐消失,获取用户的成本居高不下,几年来至少翻了十倍以上,目前平均导量成本页游为10~15元/人,手游在15~20元/人,其中IOS上成本30~50元/人,“洗”用户模式的效果正在变得微弱,用户流失严重。让我们先来看看滚服玩法的局限性,滚服洗量模式下存在着如下的弊端:

  

网游的跨服玩法是如何实现的?“跨域体系”架构设计思路 ...

 

  在上述背景下,一款长留存,低流失的精品游戏就成了平台方,渠道商,研发方追捧的目标,设想一下,如果让所有服务器玩家通过“跨域体系”实现自由畅通交互,在此基础上,玩家可以体验到前所未有的“国战系统”——7×24小时昼夜不停服的国家战争,随时开战;突破单地图承载容量极限的国战对决,带来真正万人国战的刺激体验,形成全区玩家能够互动的游戏社交环境。依托平台运营来打造一款真正意义上摆脱传统游戏运营模式的全新产品,为平台吸纳足够的市场份额,大幅降低流失率。

  我们的蓝图是开创“1=1000” 模式,让所有玩家,身处一个服务器却如同同时存在于所有服务器,这种打破服务器屏障的设定,杜绝了游戏出现“被迫滚服”现象出现,玩家不用再担心鬼服人烟稀少,不用担心交易所一无所有,所有的数据共享,让玩家轻松Hold住全世界。

  

网游的跨服玩法是如何实现的?“跨域体系”架构设计思路 ...

 

  项目组当时面临的现状是游戏各种档期计划、宣传推广安排都已经就绪,两个月后该独代项目要在腾讯平台按时上线,开发不能因引入跨服机制而导致所有完成度100%的功能都要去分别去增加跨服的支持,而技术人员在跨服功能开发这块经验的积累上也不充分。

  技术小组分析了时下项目的现状,跨服业务需求及现有的框架结构,明确了几点原则:

  为了实现跨服,游戏代码从底层架构到上层业务逻辑的代码改动成本尽量降低

  业务逻辑里尽量少关心或者不用关心是否在本服或者跨服,降低开发人员的跨服功能开发复杂度,提高开发的效率,缩短开发周期。那么,我们需要解决哪些技术疑点呢?

  客户端直连还是服务器转发

  方案A,直连。如果直连,那么,跨服玩法时客户端要维持两个连接,在跨服里,要模拟玩家登陆,绑定session的过程,游戏服和跨服两边要同时维护两份玩家数据,如何做到数据的同步?跨服要暴露给玩家,需要有公网访问IP和端口。对客户端连接管理来说较复杂。

  方案B,转发。如果通过大区服务器消息转发,那么,服务器之间做RPC通信,连接管理,消息需额外做一步跳转,性能能否满足?跨不跨服,对于客户端来说透明,跨服隐藏在大区之后,更加安全,不需再浪费公网IP和端口。

  综合考虑了下,采用了B方案。

游戏职场
  • 1
    穷途末路 一家台湾游

    在中国台湾地区台北的地下商店街,汇集...

  • 2
    原创不敌山寨:游戏开发

    自打《Threes!》(小3传奇)推出之后,各种抄袭、模仿、山寨作品层出不穷,首先冲在前的是《1024》、《2048》,接下来就是各种...

  • 3
    一本游戏杂志的转型

    从2013年下半年起,关于《大众软件》杂志可能停刊的消息便不断传出。到2013年底,原本在邮局订阅的读者发现2014年已经没有...

  • 4
    深夜交心:制作不忘初心

    文/孙志超 深夜,适合交心。 上上个周末在工场训练营中,几位CEO分享了创业初心的话题。刚好当时看到四月份创业邦杂志上...

  • 5
    免费游戏模式束缚着开发

    在今年的三月初,Fireproof公开了一个好消息,即自从我们的手机游戏《The Room》和《The Room 2》发行以来已经卖出了550万份了。...

  • 6
    一份最详细的“死亡报告

    正文 终于结束了 大家好!这是我们着手PONCHO(《斗篷》)后期制作的最后时刻,在这里,我们会谈论在这款游戏发展进程中一切...

  • 7
    游戏工作室项目管理禁做

    对于游戏研发团队来说,项目管理始终是比较重要而困难的事情,尤其是对于成立不久的工作室来说更是如此。最近,海外资...

友情链接: