乐趣区

码code | 拒绝996,不用服务器也能高效开发小游戏

不久前,GitHub 上掀起了一场反对 996 运动,国内关于“996”工作制的讨论热度也在持续上升中。如何才能避免加班,在小程序开发中少走弯路?今天我们向大家推荐一个用云开发开发小游戏的方法,摆脱对服务器的依赖,提高开发效率。
转载来源:云开发 x 原作者:代长新
前言
我是代长新,来自上海享物说,主要负责游戏客户端研发。《乐享花园》是我们在小游戏领域的第一个实践。这个游戏,从立项到做完,准确的说是客户端做完,我们一共用了 3 天的时间。
但是,当时我们种花浇花、领水滴任务都是通过浏览器缓存实现的,如果要上线还要等服务端人员到位,否则玩家清理一下手机,自己种的花就没了。但等我们服务端人员到位,再到游戏上线,就是几周以后的事情了。
小游戏开发之痛:无法摆脱对服务端的依赖
相信,这也是大部分小游戏开发时会遇到的问题 —— 功能很简单,但就是摆脱不了对服务端的依赖。如下图:
具体来说,小游戏对服务端的依赖主要有以下两个方面:
1、微信接口只支持在服务端调用
这就意味着,我们必须为这些接口架设一个中转服务器。如果没有这个中转服务器,我们就没法做用户登录,没法获取用户头像、名称信息,也拿不到 access_token,更没有办法调用其他微信接口,如内容审查。
2、游戏功能实现需要服务器开发
对于很多小游戏来说,我们唯一用到服务端的地方就是,储存当前的关卡进度,展示一个世界排行,就可以了。而想要实现这么一个简单的需求时,你会发现,隔行如隔山。
如何用云开发解决小游戏在服务端痛点?
1、云函数实现微信接口调用
曾经,我想过绕开服务器,直接通过客户端请求微信接口,结果踩了一个坑。当时做的是聊天功能,需要对玩家发送的消息进行内容审查。我看完了接口文档,就跑过去跟服务器同学说,内容审查我这边全部做掉就可以,他那边不需要做额外的处理。
等我们调通,上了体验版,一打开报错,我才想起来,这个接口文档的上面,有一行小字,而且颜色是灰色的,上面写着:此接口应在后端服务器调用。
第一次看到这句话,还以为它只不过是一个警告,所以根本没把它放在心上,哪知道它居然是一个 error!而在这之前,我还特意做了一些我认为比较人性化的设计,比如使用这个接口需要一个密钥,这个密钥是有有效期的,当密钥过期的时候,我会把玩家发送的内容保存起来,向后端拉取新的密钥后,再发送出去,这样对于玩家来说,整个过程是无感知的。而现在则意味着所有这些都要服务器去实现了。
后来,我通过云开发来实现多有接口调用,事情就简单多了。
就拿登录来说吧。
由于云函数具有微信天然鉴权的能力,可以直接返回 openid,这一点对做登录确实很方便。乐享花园需要和享物说平台打通小红花积分数据,所以需要用户的 unionid 信息,这一步也是在云函数中实现的。
还有 access_token,就是刚才用到的密钥,为什么要单独说这个密钥呢?因为它会用到云函数特别有意思的功能,那就是定时触发器。由于这个密钥是有两个小时有效期的,我们设定一个小时间隔定时刷新,保存到数据库中,用的时候直接从数据库中取出来就可以了,这样可以保证密钥永远是不过期的。
通过云开发,为微信接口准备的中转服务器就不需要了;更重要的是,服务端与微信接口分离,无需关心客户端场景。不管这个客户端,是来自 h5 游戏,还是来自小游戏环境,对于服务端来说,都是一样的,再也不需要为客户端提供这样那样的权限接口。
2、云函数 + 数据库,实现全局排行榜功能
正如前面提到的痛点,小游戏开发对服务端的另一个依赖是游戏功能的实现。对于大部分小游戏来说,我们唯一用到服务端的地方就是:保存用户数据,展示一个世界排行榜。而如果用传统服务器实现这些功能的话,你会发现需要了解的后端架构知识非常庞大。
有次,我到服务端同学的旁边,原本是打算 diss 他的,因为我功能已经写完了,他还不知道在忙些什么东西。这时我看到他在做什么呢 —— 一边写 dockfile 文件,一边写 linux 命令,一边打开 Postman 调试,完了后发邮件给运维说要执行几个 mysql 语句。而所有这些都还没有涉及到他要开发的游戏功能!
所以说,一门后端语言从会写,到可以放到生产环境中,是两个完全不一样的概念。
云开发提供了数据库、云函数、云存储,通过这些能力,我们完全可以取代服务器来实现游戏功能。
在《乐享花园》里,我们通过云开发实现了全民成语接龙这个游戏功能,并且只用了 2 个云函数就实现了我们对服务器的全部需求。这里简单介绍一下这两个云函数:
第一个云函数是用来展示世界排行榜。由于云函数拉取数据库的条目是有限制的,最大是 100 条,其实这个已经足够满足需求了;当然了,你要说我们的客户端很牛,性能不是问题,数据什么的先给我来个 2000 条,也不是不可以,这里做个处理就可以了。
另外在检索数据库数据时,这个过程会很慢,一定要记得,在后台添加数据库索引,可以把这个过程理解为通过磁盘换取 CPU 计算。这样速度会快很多。
第二个云函数是用来上报玩家数据。这个比较简单,一行代码搞定。
就这样从微信接口调用,到游戏功能开发,一款不需要服务器的小游戏就全部开发完成了。
小结
其实,云开发可以使用的业务场景,还有很多,比如,
绕过微信 https 域名请求限制 存放游戏的全局设置 保存玩家的个性化数据。。。
作为开发者,也希望云开发未来,可以提供更多的业务场景支持,比如,
websocket,刚才说的聊天服务器,就可以省掉了;帧同步,实时对战类游戏的实现,就不再有压力;日志服务,方便统计,和排查玩家的行为,方便游戏迭代优化;大数据统计分析,可以做一些事件漏斗等等~
这样小游戏的研发门槛,就降得很低很低了!

了解更多小程序开发相关内容,欢迎微信扫描下方二维码关注「微信极客 WeGeek」公众号,共筑微信生态。

退出移动版