GameLift FleETIQ 最佳实践 - Amazon GameLift
Amazon Web Services 文档中描述的 Amazon Web Services 服务或功能可能因区域而异。要查看适用于中国区域的差异,请参阅中国的 Amazon Web Services 服务入门

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

GameLift FleETIQ 最佳实践

GameLift FFleetIQ 是一个低级逻辑层,可帮助您管理用于游戏托管的 Amazon EC2 资源。GameLift FleETIQ 通过最大限度地减少游戏会话可能中断的几率来优化游戏托管的 Spot 实例的使用。它还提供基本的游戏托管功能,以跟踪可用的游戏服务器,并将游戏路由到低成本、高可行性的游戏服务器。

GameLift FleETIQ 作为独立功能,不提供与全面托管 GameLift GameLift FleETIQ 解决方案一起提供的高级功能,后者也使用 FleETIQ 来尽可能降低托管成本。如果您需要对战、基于延迟的玩家路由、游戏会话和玩家会话管理以及版本控制等功能,请查看 GameLift 解决方案。

以下是一些可以帮助您从 GameLift FleETIQ 中获得最大利益的最佳实践。

  • 在基于会话的 GameLift 中使用 FFleetIQ。 GameLift FleETIQ 在不断地将玩家引导到最不可能出现游戏会话中断的实例时,其效果最佳。保持长寿命的会话会干扰 GameLift FleETIQ 平衡过程,从而增加游戏会话可能被中断的几率。理想的工作流程是让玩家从对战(或服务器选择)到进入游戏。游戏结束后,玩家会返回到对战,并路由到新实例上的另一个游戏服务器。我们建议将用于会话 FleetIQ 少于两小时的 GameLift。

  • 提供多种实例类型以供选择。 设置游戏服务器组时,您提供要使用的实例类型列表。您包含的实例类型越多,GameLift FleETIQ 使用高可行的 Spot 实例进行游戏托管的灵活性就越大。例如,您可以列出同一个实例系列中的多种大小(c5.large、c5.xlarge、c5.2xlarge、c5.4xlarge)。对于大型实例,您可以在每个实例上运行更多的游戏服务器,从而可能降低成本。对于小型实例,自动缩放可以更快地响应玩家需求的变化。请记住,所需实例类型的列表没有优先级,Auto Scaling 组将使用可行实例类型的平衡来保持组的恢复能力。

  • 在所有实例类型上测试您的游戏。 确保游戏服务器在为游戏服务器组配置的每个实例类型上正常运行。

  • 使用实例容量加权。 如果您将游戏服务器组配置为使用某个实例大小范围(如 c5.2xlarge、c5.4xlarge、c5.12xlarge),请包括每种实例类型的容量加权信息。有关更多信息,请参阅 。Amazon EC2 Auto Scaling 的实例加权中的Amazon EC2 Auto Scaling 用户指南

  • 使用 GameLift FleETIQ 放置您的游戏会话。 使用游戏服务器放置玩家组时,请使用 GameLift APIClaimGameServer()。GameLift FleETIQ 避免将玩家置于游戏会话中断几率较高的实例上。

  • 将游戏服务器状态报告给 GameLift FleETIQ。 使用 GameLift API 定期报告服务器运行状况和利用状态UpdateGameServer()。保持准确的游戏服务器状态有助于 GameLift FleETIQ 更高效地放置游戏。它还有助于避免在 Spot 平衡活动期间终止具有活动游戏的实例。

  • 设置自动扩展策略。 您可以创建目标跟踪扩展策略,以根据玩家利用情况和预期需求维护您的主机容量。GameLift FleETIQ 指标PercentUtilizedGameServers是衡量当前正在使用的托管容量。大多数游戏希望维护未使用的游戏服务器的缓冲区,以便新玩家能够快速进入游戏。您可以创建一个保持特定缓冲区大小的扩展策略,随着玩家需求的波动添加或删除实例。有关更多信息,请参阅 。目标跟踪扩展策略Amazon EC2 Auto Scaling 用户指南中的相关信息。

  • 使用不同的Amazon用于开发和生产环境的帐户。 跨账户将您的开发配置与生产配置分开,可以减少影响现场玩家的配置错误风险。

  • 为使用中的游戏服务器组启用游戏会话保护。 为了保护玩家,请打开游戏会话保护,防止活动游戏会话因扩展或平衡活动而提前终止。

  • 在与 GameLift FleETIQ 集成之前,在 EC2 上测试游戏。 我们建议首先您在 EC2 上启动并运行您的游戏来进行调整。然后,您可以使用相同的启动模板和 AMI 创建游戏服务器组。

    如果您使用的是 Kubernetes,我们建议您首先将标准 EC2 实例添加到 Kubernetes 集群中,然后使用您在 Kubernetes 集群中为工作线程节点创建的启动模板来创建游戏服务器组。如果您使用的是 EKS,请单独创建 EKS 集群和游戏服务器组。对于游戏服务器组,请将 EKS 优化的 AMI 与合适的用户数据以及用于 EKS 集成的启动模板配置结合使用。在 Amazon EKS 优化 Linux AMI 指南中可查看有关 EKS 工作线程节点和 EKS 优化 AMI 的更多信息。

  • 使用游戏服务器组平衡策略ON_DEMAND_ONLY获取可靠的游戏服务器可用性。 使用此平衡策略后,不会使用竞价型实例。这是一个有用的工具,可在您最需要时确保服务器的可用性,例如在功能启动或其他特殊活动期间。您可以根据需要将游戏服务器组从竞价转换为按需策略。

请查看这些Amazon最佳实践: