混合托管的开发路线图 Amazon GameLift Servers - Amazon GameLift Servers

本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。

混合托管的开发路线图 Amazon GameLift Servers

此路线图将指导您如何为多人游戏开发托管解决方案。 Amazon GameLift Servers提供了多种游戏托管选项;有关这些选项的更多信息,请参阅Amazon GameLift Servers 解决方案

混合解决方案使用托管资源的组合,包括由管理的基于云的资源Amazon GameLift Servers和您自己的自行管理的托管资源。有关混合托管的更详细讨论,请参阅这篇文章:使用 Amazon GameLift Servers Anywhere 进行混合游戏服务器托管。借Amazon GameLift Servers助,您可以设置使用通用组件和流程的混合解决方案,这样您就可以集中管理全球机队并在所有类型的资源之间轻松移动负载。

混合架构包含以下组件:

  • 一个或多个Amazon GameLift Servers托管队伍,使用针对多人游戏托管进行了优化的亚马逊弹性计算云 (Amazon EC2) 实例。

  • 一个或多个 Amazon GameLift Servers Anywhere 队列,它们使用您现有的本地或其他托管资源,包括您的配置管理和部署工具。(您可以选择使用 AWS Systems Manager。)

  • 与服务器 SDK 集成的单一游戏服务器版本Amazon GameLift Servers,可在所有舰队中部署。

  • 与 AWS SDK 集成的单个游戏客户端和后端服务,用于与Amazon GameLift Servers服务交互并请求游戏会话。

  • 共享Amazon GameLift Servers队列,用于在可用的游戏服务器上放置新的游戏会话,并在所有舰队之间平衡负载。

  • Amazon GameLift ServersAgent 与 Anywhere 队列一起部署,用于简化所有队列中计算机上的服务器进程管理任务。

  • (可选)匹配器,用于创建多FlexMatch人比赛并为其设置游戏会话。

该路线图为在混合托管解决方案中成功启动和运行多人游戏提供了简化的途径Amazon GameLift Servers。准备好必要的组件后,您就可以继续迭代游戏开发并自定义您的托管解决方案。临近发布时,请参阅通过Amazon GameLift Servers托管为游戏发布做准备,帮助您为生产级使用准备托管解决方案。

快速开始使用该Amazon GameLift Servers插件

如果你正在使用虚幻引擎或Unity开发项目,请使用该Amazon GameLift Servers插件开始设置游戏以进行托管。使用该插件,您可以将Amazon GameLift Servers SDKs 添加到您的游戏项目中,并使用指导式工作流程来构建混合托管解决方案的简单工作版本,该解决方案包含 Anywhere 队列和托Amazon GameLift Servers管队列。然后,您可以在这些基础上进行构建和按需自定义。

为您的游戏服务器添加功能,使其在部署用于托管时可以与Amazon GameLift Servers服务通信。如果游戏服务器在Amazon GameLift Servers托管队列或 Anywhere 队列上运行,则需要相同的功能。

  • 为您的游戏项目获取适用于 Amazon GameLift Servers(版本 5.x)的服务器 SDK。服务器 SDK 有 C++、C# 和 Go 版本。下载适用于的服务器 SDK Amazon GameLift Servers

  • 修改游戏服务器代码以添加服务器 SDK 功能。有关指南,请参阅将游戏与自定义游戏服务器集成。至少执行以下操作:

    • 添加代码以初始化 Amazon GameLift Servers SDK 并与Amazon GameLift Servers服务建立 WebSocket 连接。使用服务器 SDK 操作 InitSdk()。在 Anywhere 实例集计算上运行时,加入指定服务器参数的代码。

    • 添加代码,以便在服务器进程准备好托管游戏会话时向Amazon GameLift Servers服务报告。使用服务器 SDK 操作 ProcessReady()

    • 实现所需的回调函数OnProcessTerminate(),以及OnStartGameSession()。借助这些功能,游戏服务器进程可以与Amazon GameLift Servers服务保持连接,在出现提示时启动游戏会话Amazon GameLift Servers,并响应提示结束游戏服务器进程。

    • 添加代码,以便在服务器进程结束游戏会话时向Amazon GameLift Servers服务报告。使用服务器 SDK 操作 ProcessEnding()

  • 打包游戏服务器生成包。使用生成包文件、依赖项和支持软件创建安装脚本。请参阅打包游戏生成包文件。我们建议使用 Amazon Simple Storage Service(Amazon S3)存储桶来存储游戏生成包的版本。

  • 测试游戏服务器集成。对于此任务,我们建议使用本地工作站设置 Amazon GameLift Servers Anywhere 队列,如中所述使用 Amazon GameLift Servers Anywhere 设置本地测试。在此步骤中,手动将游戏服务器生成包安装到测试设备上,然后启动服务器进程。使用 AWS CLI 请求新的游戏会话,并验证Amazon GameLift Servers服务是否成功提示您的服务器进程启动游戏会话。

为您的游戏客户端创建一种方法,使其能够请求加入游戏会话、获取连接信息,然后直接连接到托管的游戏会话。最常见的方法是设置后端服务功能,作为游戏客户端和Amazon GameLift Servers服务之间的中间人。此方法可以保护您的托管资源,并让您更好地控制玩家进入游戏会话的方式。

  • 构建用于托管的后端服务功能。后端服务与服务通信并将连接信息提供给游戏客户端。Amazon GameLift Servers此功能包括启动游戏会话、将玩家放入游戏以及检索游戏会话信息。有关指南,请参阅将游戏与自定义游戏服务器集成。至少执行以下操作:

  • 向游戏客户端添加允许玩家加入托管游戏会话的功能。游戏客户端向你的后端服务发出请求,而不是直接向后端服务发出请求Amazon GameLift Servers。在后端服务提供游戏会话连接信息后,游戏客户端会直接连接到游戏会话来玩游戏。

  • 测试游戏客户端集成。您可以将相同的 Amazon GameLift Servers Anywhere 队列与本地工作站一起使用进行测试。

    在开发阶段,如果您想测试游戏版本在Amazon GameLift Servers托管队列中的表现,我们建议您同时设置基于云的测试环境。此 Amazon GameLift Servers Toolkit 解决方案模仿托管舰队的行为,但允许您在最短的周转时间内更新游戏服务器版本。

自定义处理新游戏会话请求的方式,并找到可用的游戏服务器来托管这些请求。Amazon GameLift Servers Amazon GameLift Servers自动跟踪所有舰队中所有游戏服务器的可用性。当游戏客户端发送加入游戏会话的请求时,会根据一组已定义的优先级(例如最小延迟、成本和可用性)寻Amazon GameLift Servers找 “最佳” 的位置。

  • 创建游戏会话队列,用于将新的游戏会话与可用的游戏服务器一起放置。队列是游戏会话放置的主要机制。有关指南,请参阅创建游戏会话队列

    • 至少在队列中将您的 Anywhere 实例集添加为目标。所有其他设置都是可选自定义项。

  • 在后端服务代码中,将 CreateGameSession() 调用转换为 StartGameSessionPlacement()请参阅 Create a game session in a multi-location queue

  • 创建一个机制,用于在游戏会话准备好加入时通知游戏客户端。在开发过程中,你可以通过致电来轮询游戏会话状态 DescribeGameSessionPlacement。但是,在使用队列处理大量数据之前,您需要启用事件通知。请参阅请参阅设置游戏会话置放通知。

  • (可选)添加FlexMatch配对组件。有关指导,请参阅Amazon GameLift ServersFlexMatch开发者指南

到目前为止,您一直在使用本地设备(注册为 Anywhere 队列计算)来测试和迭代游戏组件。下一步是设置生产系统所需的实例集类型。从 Anywhere 队列开始,然后添加Amazon GameLift Servers代理来管理一些关键的计算主机管理任务。有关更多详细信息,请参阅 与Amazon GameLift Servers代理合作

  • 获取Amazon GameLift Servers代理并将其添加到您的游戏服务器安装包中。获取并编译代理源代码,该源代码位于 Github Amazon GameLift Servers 代理存储库中。将生成的 JAR 文件可执行文件放在与游戏生成包可执行文件相同的目录中。

  • 根据需要修改代理的启动脚本。确保在计算开始运行后立即启动代理可执行文件。如需获取在托管计算上安装和运行代理方面的帮助,请参阅代理存储库中的自述文件。您的启动命令应包括至少指定 Anywhere 队列 ID AWS 区域、自定义位置和计算名称的选项。

    代理会自动为您处理以下任务,因此,如果您一直使用脚本处理这些任务,则可以将脚本删除:

    • 调用 RegisterCompute(),将计算添加到 Anywhere 实例集。

    • GetComputeAuthToken()在游戏服务器连接到Amazon GameLift Servers服务时调用对其进行身份验证。代理负责管理身份验证令牌的获取和刷新,在计算上运行的所有游戏服务器进程都可以使用该令牌。

    • 根据一组运行时指令在计算上启动新的服务器进程。

  • 为 Anywhere 实例集中的计算创建运行时配置。至少为游戏服务器可执行文件指定启动路径。您可以使用Amazon GameLift Servers控制台或 AWS CLI 为队列创建或修改运行时指令。代理执行这些指示,并定期向Amazon GameLift Servers服务请求更新。

  • 根据需要设置或修改游戏会话队列。创建新队列(或更新现有队列),并为随Amazon GameLift Servers代理部署的 Anywhere 队列指定目的地。

  • 测试代理与 Anywhere 实例集的集成。检查代理是否根据运行时配置正确启动服务器进程。

创建Amazon GameLift Servers托管 EC2 舰队来补充你的 Anywhere 车队。如果您在步骤 2 中设置了基于云的测试环境以加快开发速度,请计划在完成大部分游戏开发和测试后创建托管式实例集。您需要一个完全托管式实例集来配置和测试其他设置,如自动容量扩展。

  • Package 你的游戏服务器版本并上传到Amazon GameLift Servers。使用生成包文件、依赖项和支持软件创建安装脚本。您可以对 Anywhere 和托管式实例集使用相同的生成包软件。请参阅为部署自定义服务器版本 Amazon GameLift Servers 托管。您可以使用控制台或 AWS CLI 将您的版本上传到Amazon GameLift Servers。

    在上传生成包之前,请确定要在哪个 AWS 区域 中创建托管式实例集。您必须将生成包上传到同一区域。有关选择实例集位置的更多信息,请参阅实例集位置

  • 创建托管 EC2舰队。您可以使用Amazon GameLift Servers控制台或 AWS CLI 创建托管队列。创建队列后,Amazon GameLift Servers会立即开始部署游戏服务器版本进行托管。您可以配置托管式实例集的许多方面。有关指南,请参阅创建Amazon GameLift Servers托管 EC2 舰队。至少执行以下操作:

    • 为实例集命名并指定要部署的已上传游戏生成包。

    • 为实例集选择按需型实例,并选择在实例集所在位置可用的实例类型。竞价型实例集是一个很有价值的选择,但需要额外的设计和配置。

    • 使用与 Anywhere 实例集相似的设置创建运行时配置。至少为游戏服务器可执行文件指定启动路径。

    • 指定端口设置以允许入站流量访问游戏服务器。

  • 将托管式实例集添加到共享游戏会话队列。更新步骤 4 中的队列,使其包含托管队列和随Amazon GameLift Servers代理部署的 Anywhere 队列的目的地。

  • 使用托管式实例集测试游戏托管。此时,您应该能够测试整个托管周期,即游戏客户端请求游戏会话、获取连接信息和成功连接到游戏会话。

在为游戏发布做准备时,您需要对托管解决方案进行微调。需要考虑的决策包括:

  • 对于 Anywhere 实例集,根据需要自动启动和关闭计算,包括安装和运行游戏服务器软件。回收计算有助于确保计算定期更新,而关闭不需要的计算则可以节约成本。

  • 如果您的游戏服务器需要与其他 AWS 资源通信,请设置 IAM 角色来管理访问。请参阅与舰队中的其他 AWS 资源进行沟通

  • 确定要将游戏服务器放置在哪个地理位置。将偏远位置添加到您的托管式实例集。请参阅自定义你的 Amazon GameLift Servers EC2 托管车队

  • 对于托管式实例集,考虑使用竞价型实例集来节省成本。请参阅教程:使用竞价型实例创建Amazon GameLift Servers队列

  • 通过选择计算资源配置来优化实例集性能,然后配置运行时指令,使每个计算运行最优数量的服务器进程。请对 Anywhere 实例集和托管式实例集执行此操作。请参阅管理如何 Amazon GameLift Servers 启动游戏服务器

  • 试验适用于托管式实例集的游戏会话放置选项,包括自定义优先级设置。请参阅自定义游戏会话队列

  • 对于托管式实例集,设置自动容量扩展以满足预期的玩家需求。请参阅通过以下方式扩展游戏托管容量 Amazon GameLift Servers

  • 对于 Anywhere 实例集,创建处理手动或自动容量扩展的机制,以满足预期的玩家需求。

  • 根据需要设计并实施到其他资源的失效转移。在其他 AWS 区域 中设置备用实例集,并修改队列和自动扩缩,以便在需要时处理失效转移。

  • 设置托管可观测性工具,包括分析和日志记录。请参阅监控 Amazon GameLift Servers。创建指标组以汇总所有托管资源的分析。

  • 使用基础设施即代码(IaC)自动执行部署。请参阅管理 Amazon GameLift Servers 使用托管资源 AWS CloudFormation

    Amazon GameLift Servers支持将 AWS CloudFormation 模板用于任何特定于部署的配置。您也可以使用 AWS Cloud Development Kit (AWS CDK) 来定义您的Amazon GameLift Servers资源。有关更多信息 AWS CDK,请参阅《AWS Cloud Development Kit (AWS CDK) 开发人员指南》

    要管理 AWS CloudFormation 堆栈的部署,我们建议使用持续集成和持续交付 (CI/CD) 工具和服务,例如。 AWS CodePipeline这些工具可以帮助您在构建游戏服务器二进制文件时自动部署或在获得批准的情况下进行部署。使用 CI/CD 工具或服务,新游戏服务器版本的资源部署可能如下所示:

    • 构建和测试游戏服务器二进制文件。

    • 将二进制文件上传到Amazon GameLift Servers。

    • 部署具有新生成包的新实例集。

    • 将新实例集添加到游戏会话队列,并删除具有先前生成包版本的实例集。

    • 当具有先前生成包的实例集不再托管活动游戏会话时,请删除这些实例集的 AWS CloudFormation 堆栈。