【从零开始学Skynet】实战篇《球球大作战》(一):功能设计

news2025/1/18 11:54:48

         为了能把之前在基础篇中学习到的Skynet的各种知识结合起来,所以在实战篇中,我们准备开发一个完整的游戏案例《球球大作战》,介绍分布式游戏服务端的实现方法。

1、功能需求

        《球球大作战》是一款多人对战游戏,下图是它的战斗场景示意图。玩家控制一个小球,让它在场景中移动。场景会随机产生食物,小球吃掉(碰到)食物后,体积会增大。数十名玩家在同一场景对战,体积大的玩家可以吃掉体积小的玩家。

 2、游戏流程

  • 玩家输入账号密码登录游戏;
  • 进入如下图所示的界面,可以设置本轮游戏的昵称、选择服务器;
  • 当玩家点击界面中的“开始比赛”按钮时,会进入某一战斗场景,在这里可与其他玩家对战。

         我们即将开发的这款游戏,预估会有数万到数十万玩家同时在线,所以服务端也要根据这个量级来设计。

 3、方案设计

        要支持数以万计的在线玩家,必然要采取分布式的设计方案。     

 (1)拓扑结构

        我们设计了如下图所示的服务端结构,其中圆圈代表服务,圈内文字指明服务的类型和编号,比如“gateway1”代表“gateway”类型的1号服务

 此服务端结构有如下特点:

  • 可以支持多个节点横向拓展。理论上,只要开启更多节点,就能够支持更多玩家;
  • 符合Skynet设计理念。每个服务都是轻量级的,功能单一,通过多个服务协作完成服务端功能;
  • 每个节点被划分成两部分,其中,用虚线方框围起来的称为“本地”服务,方框外的称为“全局”服务。
类型说明
本地服务

        在单节点内是唯一的,但是它是不具备全局唯一性的服务,比如图中节点1节点2都有login1,每个节点都可以开启一个login1,它们各自独立

全局服务        是在所有节点中都具有唯一性的服务。比如图中的agentmgr,可以把它部署在节点1,或者节点2上,但是无论如何,所有节点只能开启一个

(2)各服务功能

        服务端包含了gateway、login等多个类型的服务,它们的功能如下表所示:

服务说明
gateway

        即网关,用于处理客户端连接的服务。客户端会连接某个网关(gateway),如果玩家尚未登录,网关会把消息转发给节点内某个登录服务器,以处理账号校验等操作;如果登录成功,则会把消息转发给客户端对应的代理(agent)。

        一个节点可以开启多个网关以分摊性能。

login

        指登录服务,用于处理登录逻辑的服务,比如账号校验。

        一个节点可以开启多个网关以分摊性能。

agent        即代理,每个客户端会对应一个代理服务(agent),负责对应角色的数据加载、数据存储、单服逻辑的处理(比如强化装备、成就等)。出于性能考虑,agent必须与它对应的客户端连接(即客户端连接的gateway)处在同一个节点。
agentmgr        管理代理(agent)的服务,它会记录每个agent所在的节点,避免不同的客户端登录同一账号。
nodemgr        指节点管理,每个节点会开启一个nodemgr服务,用于管理该节点和监控性能。
scene        即场景服务,处理战斗逻辑的服务,每一局游戏由一个场景服务器负责。

(3)消息流程

        从客户端发起连接开始,服务端内部的消息处理流程如下图所示(这是个简化图,忽略了nodemgr)。

  • ​​​​​​​ 登录过程:

        在阶段①客户端连接某个gateway,然后发送登录协议。gateway将登录协议转发给login(阶段②),校验账号后,由agentmgr创建与客户端对应的agent(阶段③和④)完成登录。如果该玩家已在其他节点登录,agentmgr会先把另一个客户端顶下线。

  • 游戏过程:

        登录成功后,客户端的消息经由gateway转发给对应的agent(阶段⑤),agent会处理角色的个人功能,比如购买装备、查看成就等。当客户端发送“开始比赛”的协议时,程序会选择一个场景服务器,让它和agent关联,处理一场战斗(阶段⑥)。

(4)设计要点

  1、gateway

        这套服务端系统采用传统C++服务器的架构方案。gateway只做消息转发,启用gateway服务有以下好处:

  • 隔离客户端与服务端系统。如果要更改客户端协议(比如改用json协议或protobuf),仅需更改gateway,不会对系统内部产生影响。     
  • 预留了断线重连功能,如果客户端掉线,仅影响到gateway。                       

        然而引入gateway意味着客户端消息需经过一层转发,会带来一定的延迟。将同一个客户端连接的gateway、login、agent置于同一节点,有助于减少延迟。

2、agent和scene的关系

        agent可以和任意一个scene通信,但跨节点通信的开销较大。一个节点可以支撑数千名玩家,足以支撑各种段位的匹配,玩家应尽可能地进入同一节点的战斗场景服务器(scene)。

3、 agentmgr

        agentmgr仅记录agent的状态、处理玩家登录、登出功能,所有对它的访问都以玩家id为索引。它是个单点,但很容易拓展成分布式。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/422798.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C语言库函数(memcpy,memmove)的模拟实现

模拟实现memcpy函数 下面是memcpy的函数声明 void *memcpy(void *str1, const void *str2, size_t n) 参数 str1 -- 指向用于存储复制内容的目标数组,类型强制转换为 void* 指针。str2 -- 指向要复制的数据源,类型强制转换为 void* 指针。n -- 要被复…

stm32当中的EXTI外部中断系统

一. 中断系统 中断 : 在主程序运行过程中,出现特定的中断触发条件,使得CPU暂停当前正在运行的程序,而去处理中断程序,完成后,又返回原来被暂停的位置继续工作 中断优先 : 当有多个中断开始时&…

SSR初体验-结合Vue3全家桶

SSR初体验 基础搭建 安装依赖 先开启一个服务器 let express require("express");let server express();server.get("/", (req, res) > {res.send(Hello Node Server); });server.listen(3000, () > {console.log("start node server on …

vue3引入Element plus的详细步骤

目录 一、遇到问题 二、操作步骤 一、遇到问题 在用vue3去引用Element UI的时候,发现了白屏不能显示,一直检查是不是代码的问题。后面找到了问题的所在,原来是vue3对应兼容的是Element Plus,要去下载对应的Element plus版本来引…

为什么提升客户服务是长期成功的关键

当今互联网,服务越来约趋向个人化,但在这个在线互动的时代,当涉及到客户支持时,这种个人联系的感觉可能很难形成。当事情出错时,当客户需要支持时,个人联系的感觉最为强烈。在不远的过去,客户支…

网络安全如何入门?有哪些学习误区?

那年我高三毕业的时候要填志愿前几天 我妈问我想学什么专业。 我说,想学网络设计、或者计算机、网络安全工程师 那时候还比较年轻,也对网络,计算机这方面感兴趣嘛 于是我妈和我爸决定让我学网管。 我说不想做网管,想直接成为一…

给想涨薪和正在学习Android的朋友们一些建议

前言 相信很多从事Android开发工作的朋友,在入职一年后会有申请涨薪的想法,但由于某些原因,公司拒绝了您的加薪申请,在我看来,出现这种情况主要有两种原因:第一个原因可能是你在工作中就只知道埋头苦干&am…

81-82-83-84-85-86 - 文件系统设计与实现

---- 整理自狄泰软件唐佐林老师课程 查看所有文章链接:(更新中)深入浅出操作系统 - 目录 文章目录1. 问题1.1 硬盘上最最最简单的文件系统支持方式1.2 改进思路1.3 更多细节问题1.4 文件系统概要设计1.5 硬盘数据逻辑示意图1.6 硬盘数据物理组…

文心一言 VS chatgpt (8)-- 算法导论2.3 5~6题

五、回顾查找问题(参见练习 2.1-3),注意到,如果序列 A 已排好序,就可以将该序列的中点与v进行比较。根据比较的结果,原序列中有一半就可以不用再做进一步的考虑了。二分查找算法重复这个过程,每次都将序列剩余部分的规…

数据结构之七大排序

数据结构之七大排序🔆排序的概念及其运用排序的概念常见的排序算法🔆插入排序直接插入排序希尔排序🔆选择排序直接选择排序堆排序🔆交换排序冒泡排序快排🔆归并排序🔆非比较排序🔆结语&#x1f…

深度探索list

1.list的基本组成 list是一个双向链表,它的基本组成就是 成员作用prev指针指向上一个元素next指针指向下一个元素data用来保存数据2.list的迭代器 由于人们一般习惯于:迭代器是找到下一个元素,迭代器–是找到上一个元素。在双向链表list中…

C++的命名空间

C和C语言是有一些相似的地方的,而且C就是C语言的改进版本,所以学习C也得学习C语言,但是他们又是有很多不同的地方 下面我们就看一下C的命名空间 我们首先看一下 如果是这一段代码,那么这里输出的是多少呢? 很好这里输…

Nacos服务端服务注册源码分析 - 篇四

Nacos服务端服务注册源码分析 - 篇四 服务端调用接口 嗨 ~~~ 上班除了无聊的摸鱼,我还学了一个新技能,偷偷写博客。。。。 我们先回忆一下之前的三篇文章 🕐Nacos 客户端服务注册源码分析-篇一 🕑Nacos 客户端服务注册源码分析…

路由器的两种工作模式及快速通过express搭建微型服务器流程,解决刷新页面服务端404的问题

history模式与hash模式 首先这个#叫做hash,最大的特点就是不会随的http请求,发给服务器。 默认的模式是hash模式,如果想要修改,可以在router里面的index.js中配置mode属性, 它们俩直接的区别最明面上的有没有#和hist…

Python第三方库安装

看见更大的Python世界 Python社区PyPI The Python Package Index PyPI: Python Package Index PSF维护的展示全球Python计算生态的主站 学会检索并利用PyPI,找到合适的第三方库开发程序 实例:开发与区块链相关的程序 第1步:在pypi.org…

【服务器数据恢复】EVA存储数据硬盘掉线导致LUN不可用的数据恢复

服务器数据恢复环境: HP-EVA存储环境:EVA某型号控制器EVA扩展柜FC硬盘。 服务器故障: EVA存储中两块磁盘掉线导致存储中某些LUN丢失不可用。 服务器数据恢复过程: 1、首先对故障存储中所有磁盘做物理故障检测,经过…

在Spring Boot微服务使用RedisTemplate操作Redis

记录:400 场景:在Spring Boot微服务使用RedisTemplate操作Redis缓存和队列。 使用ValueOperations操作Redis String字符串;使用ListOperations操作Redis List列表,使用HashOperations操作Redis Hash哈希散列,使用SetO…

基于LNMP架构搭建网站

一、编译安装Nginx 服务 1、编译安装Nginx 服务的操作步骤 systemctl stop firewalld systemctl disable firewalld setenforce 01.1 安装依赖包 yum -y install pcre-devel zlib-devel gcc gcc-c make1.2 创建运行用户 useradd -M -s /sbin/nologin nginx1.3 编译安装 cd…

Claude注册安装教程【403 Forbidden】

Claude注册安装教程 尝试注册Claude的兄弟需要注意,最后一步需要科学上网 本来打算看看csdn,结果可能是时效性,和我情况不一样 按照他们的意思,点击add a stack 就进去了,我却被403 这个时候我就搜索stack,…

钢网是SMT生产使用的一种工具,如何制作?

钢网是SMT生产使用的一种工具,其主要功能是将锡膏准确地涂敷在有需要焊接的PCB焊盘上。 钢网的好坏,直接影响印刷工作的质量,目前一般使用的金属钢网,是由薄薄的、带有小孔的金属板制作成的,在开孔处,锡膏…