站务联系

揭秘游戏服务器,不看后悔!!!建议收藏!

发布时间:2022-01-02   来源:网络整理    
字号:

前言

《摩尔庄园》前段时间上线, 持续超出市场预期,相信也有不错的收益。游戏好玩,所有玩家看到了前端,但是做一款游戏,离不开后台游戏服务器的支持,服务器都要做什么,服务器的架构是什么,需要哪些技术,一系列的问题有没有思考过?下面讲下作为做服务器开发中需要做的事。

1、常见游戏模块

游戏玩法

游戏开发中常见的玩法模块,一般的游戏都会包含这些玩法

新手引导、任务系统、背包系统、装备系统、副本、战斗系统、活动、商店、充值,竞技场,公会系统,好友系统、聊天系统、邮件系统、红点系统等等

通用模块

定时job,处理一些定期活动重置,排名发奖励等

登录,顶号,离线,断线重连处理

敏感词检测,版署需要

日志系统,记录玩家行为日志,奖励日志等

功能开启关闭,有时候游戏出问题后(比如刷奖励)指定功能需要及时关闭

掉落,奖励随机规则

防沉迷系统,主要是未成年人保护规则

揭秘游戏服务器,不看后悔!!!建议收藏!

账号封号,解封,禁言

查询当前在线人数

我自己的专栏:游戏系统设计_香菜-CSDN博客

2、开发语言与项目构建发布

一般游戏服务器使用C++,nodejs,photon, JAVA等语言开发,端游戏一般选择C++,因为端游对服务器的性能要求相对比较高一些,语言各有利弊,C++效率高,但是掌握度难些,JAVA易于掌握,开发效率搞,目前对于追求快速上线率的页游和手游来说,JAVA成了一个不错的选择,下面主要以JAVA项目来讲述服务器各模块之间如何交互,如何分工合作。项目采用maven框架构建,简化了项目依赖管理, jar包便于与持续集成工具(jenkins)整合一键打包发布svn,一般地,游戏服务器的架构划分如下三层:网络接入层、游戏逻辑层、数据存储层

网络接入层

通信方面使用Netty框架,主要封装各种物理底层通讯机制,让应用程序员关注业务逻辑。协议数据使用protobuff, Protobuf有更高的消息压缩率,时间效率和空间效率都有很大的提升,支持多语言,跨平台

数据缓存以及存储

市面用的游戏用到的数据库大多是下面这几种:

MySQL,MongoDB, Redis

游戏服务器都配备了数据库,是因为游戏越来越复杂,数据量也越来越多,而且采用数据库也方便对数据的管理和备份。mysql主要存储一些游戏中玩家数据,redis主要存储一些跨服数据,比如跨服排行榜数据实时排名,或者数据的缓存。

游戏中玩家数据需要及时响应,及时反馈,一般游戏中绝大部分的数据是有缓存的,游戏中玩家产生的数据变化,一般先修改玩家缓存数据,一定时间后,缓存数据定时批量写入数据库,长期使用不到的缓存将会被清理,减少内存空间使用。

揭秘游戏服务器,不看后悔!!!建议收藏!

服务器架构 :

注:platform 和多个游戏服相连接。

流程说明:

登陆流程:玩家登陆时首先连接web服,进行登陆,验证成功后,会将玩家登陆的token 放到Gate服。然后玩家连接Gate服登陆到Game服。

图说天下

×
二维码生成