极致成本,如何基于容器计算服务 ACS 打造企业级幻兽帕鲁私服 SaaS 服务?

本文主要是介绍极致成本,如何基于容器计算服务 ACS 打造企业级幻兽帕鲁私服 SaaS 服务?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

作者:韩运韬(青炽)

《幻兽帕鲁》是一款最近大热的开放世界生存游戏。据报道。上市不到一周,《幻兽帕鲁》销量已突破 700 万份,成为名副其实的现象级游戏。根据游戏数据库网站 SteamDB 的数据显示,《幻兽帕鲁》Steam 同时在线人数最高达到 201 万,成为史上同时在线玩家数量最高的付费游戏之一。

在游戏中,玩家可以和队友一起,收集神奇又可爱的生物“帕鲁”,并与他们一道探索、建造和战斗。开发商 Pocketpair 提供了官方的私服方案,可以突破官方服务器的 4 人组局限制,并推荐广大玩家采用。本文将介绍如何使用容器计算服务 ACS,以私服服务商视角,打造低成本的企业级幻兽帕鲁私服 SaaS 服务。

部署您的第一个容器化帕鲁私服

阿里云容器计算服务 ACS (Alibaba Cloud Container Compute Service) 是以 K8s 为使用界面提供容器算力资源的云计算服务,提供符合容器规范的算力资源。算力交付模式为 Serverless 形态,您无需关注底层节点及集群的运维管理。

使用 ACS,您可以以熟悉的 K8s 界面实现 SaaS 层业务逻辑,而不必过多学习云产品 OpenAPI。

创建 ACS 集群

进入容器计算服务控制台,进入【集群】菜单,点击【创建集群】。

图片

按照要求配置合适的资源,注意勾选【使用 EIP 暴露 API Server】。

获取 KubeConfig,连接集群

待集群创建完毕后,您可以进入集群详情页,在【集群信息】-【连接信息】中找到 KubeConfig 用于本地连接集群,或直接点击右上角【通过 CloudShell 管理集群】打开 Web Terminal。

图片

开始部署

先通过 kubectl 创建一个 namespace:palworld。

kubectl create ns palworld

通过 kubectl 在集群中 apply 以下 yaml 内容:

apiVersion: v1
kind: ConfigMap
metadata:name: palworld-cmnamespace: palworld
data:PUID: "1000" # 服务器运行时的用户的 UIDPGID: "1000" # 服务器运行时的组的 GIDPORT: "8211" # 游戏本地客户端连接的端口PLAYERS: "16" # 可同加入服务器的最大玩家数SERVER_PASSWORD: "worldofpals" # 服务器密码MULTITHREADING: "true"RCON_ENABLED: "true"RCON_PORT: "25575" # RCON 连接端口TZ: UTC # 备份服务器时所使用的时间戳COMMUNITY: "false"  # 服务器是否显示在社区服务器页中SERVER_DESCRIPTION: ""
---
apiVersion: v1
kind: Secret
metadata:name: palworld-secretsnamespace: palworld
type: Opaque
stringData:rconPassword: yourRconPassword
---
apiVersion: v1
kind: Service
metadata:labels:app: palworld-servername: palworld-servernamespace: palworld
spec:ports:- name: serverport: 8211protocol: UDPtargetPort: server- name: queryport: 27015protocol: UDPtargetPort: queryselector:app: palworld-servertype: LoadBalancer
---
apiVersion: apps/v1
kind: Deployment
metadata:labels:app: palworld-servername: palworld-servernamespace: palworld
spec:replicas: 1selector:matchLabels:app: palworld-servertemplate:metadata:labels:app: palworld-serveralibabacloud.com/instance-type: standard # ACS通用型实例spec:containers:- name: palworld-serverimage: thijsvanloef/palworld-server-dockerimagePullPolicy: IfNotPresentresources:limits:cpu: 4memory: 16Girequests:cpu: 4memory: 16Giports:- containerPort: 8211name: serverprotocol: UDP- containerPort: 27015name: queryprotocol: UDPenv:- name: ADMIN_PASSWORDvalueFrom:secretKeyRef:name: palworld-secretskey: rconPasswordenvFrom:- configMapRef:name: palworld-cmvolumeMounts:- mountPath: /palworldname: datadirvolumes:- name: datadirpersistentVolumeClaim:claimName: palworld-nas
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:name: palworld-nasnamespace: palworld
spec:accessModes:- ReadWriteManyresources:requests:storage: 10PistorageClassName: alicloud-nas

在上例中,我们创建了:

  1. 帕鲁私服所需的相关配置项
  2. 帕鲁私服的 Deployment
    1. 这里我们使用了社区提供的镜像:thijsvanloef/palworld-server-docker
    2. 由于游戏服务实例是有内存状态的,所以我们 replicas 保持为 1 即可
    3. 官方推荐的 4c16g 规格在入门场景中远远过剩,建议您将起步规格优化为 4c8g 或更低,以节省成本。ACS 基于 Kubernetes 的使用界面,支持 cpu/memory 的 1:1~1:8 自由配比。相比于传统方案,让规格变配更简单
  1. 帕鲁私服所需的 PVC,以将游戏的状态持久化到外部
    1. 这里我们使用了 alicloud-nas 存储类,不要为 10Pi 这个值感到害怕,NAS 是按量付费的,10Pi 只是表示最大容量
  1. 基于 LoadBalancer 的 Service
    1. 游戏服务需要以 UDP 协议暴露出去

当 Pod palworld-server 的状态为 Running,玩家就可以通过《幻兽帕鲁》游戏客户端与小伙伴愉快的联机啦:

图片

图片

图片

当然,以上只是单个私服实例的部署示例,在商业化场景中,您可能需要将上述 YAMl 封装为 Helm Chart 以简化部署步骤(这里有个社区的参考案例 [ 1] ),或尝试阿里云开源的 OpenKruiseGame [ 2] 来实现更高级的运维能力。

ACS 如何极致降本

作为 SaaS 化私服服务商,我们需要尽可能的压低资源成本。在私服 SaaS 的商业模式中,云资源占据成本的主要部分,如何尽可能降低云资源成本,成为了业务成功的关键。

Serverless K8s,无需关心资源碎片

作为 SaaS 服务商,我们不可避免地会根据不同用户的需求提供不同等级的服务。也就是说,我们将同时运行着大小不一的各种规格实例。

如下图右侧所示,在标准的 Kubernetes 方案中,对于大规格实例(如支持 20 人以上),可能将直接占满一台 4c32g 的机器;而对于小规格实例和中规格实例,在一个 4c32g 的 Node 上运行必然会产生一些资源碎片,无形中消耗着成本。

而在 ACS 中,我们无需关心节点概念和背后的调度细节。如下图左侧所示,ACS 会为每个不同规格的实例分配对应的资源,用户只需按量付费,不用担心资源碎片产生的浪费。

图片

全栈 Serverless,不只是计算

除了计算资源本身,我们在上例中使用的网络和存储资源默认也是 Serverless 化的。

上例中,我们创建了 type: LoadBalancer 的 Service 资源,该资源将默认创建对应的按量付费的阿里云 CLB 实例。当没有玩家使用私服时,CLB 实例将不产生费用。

上例中,我们还使用 alicloud-nas 存储类创建了 PVC 资源,当 PV 产生时,该资源将默认创建按量付费的阿里云 NAS 实例。按量付费的 NAS 实例将按照实际的存储量进行扣费,对于游戏私服这种存储量低的场景将极具成本优势。

游戏业务具有明显的峰谷特征,SaaS 厂商完全可以基于业务属性对私服实例进行开服、停服以节省成本。

例如,在业务上巡检私服实例,当发现玩家数保持为 0 的五分钟后,将私服实例副本数缩 0。此时对应的 ACS Pod 将不进行计费,CLB 由于服务停止也几乎不产生流量费用,只有 NAS 实例将为该私服的持久化数据收记少量费用。

同时,可以在业务上要求用户需主动触发开服操作(可以在用户“获取服务器信息”的时候触发),此时将对应实例副本数置为 1。

通过这种业务设计,结合容器计算服务 ACS 的全栈 Serverless 特性,将为 SaaS 服务商大幅降低成本。而 ACS 本身所支持的 K8s 操作界面也为业务缩放提供了便利。

任务型工作负载大幅降本

私服 SaaS 服务商可能对不同的用户提供不同的差异化方案。如果服务商希望通过提供较低 SLA 保障的方案挖掘下沉市场,或是需要通过免费版拉新,则可以充分利用容器计算服务 ACS 的任务型工作负载进一步大幅降低成本。

在上例中,我们使用了 ACS 的默认实例类型:通用型实例去创建 palworld-server 工作负载。即为 spec.template.labels 加上了如下标签:

alibabacloud.com/instance-type: standard

通用型实例也是 ACS 默认的 Pod 实例类型,适合大部分延迟敏感型工作负载。在大多数场景中,通用型工作负载能够取得性能与经济性的平衡。

而对于延迟不敏感、性能不敏感的场景,我们可以使用 ACS 任务型实例大幅降本:

alibabacloud.com/instance-type: best-effort

与通用型、独享型实例相比,使用任务型实例可以节省相当可观的资源成本。任务型实例使用的 vCPU 与宿主机节点的物理 CPU 并不是严格绑定的,实例进程在运行过程中会被随机调度到任何空闲的 vCPU 超线程上,不同类型实例的 vCPU 会分时共享物理 CPU 资源,在宿主机节点低负载时,任务型实例可以获得较好的算力性能,在高负载时可能会出现 CPU 算力受限的情况。

图片

通常来说,在相同规格的情况下,受操作系统调度算法影响,任务型实例整体生命周期内的 CPU 算力基准低于通用型实例。下图展示了一个视频转码应用,在通用型和任务型实例类型下的运行时间情况对比。

图片

🔔 注意: ACS 对任务型实例的运行时长有限制。在邀测期间,单个实例的最大运行时长为 24 小时。

写在最后

以上就是容器计算服务 ACS 在私服 SaaS 服务商场景的使用案例。ACS 目前正处于邀测阶段,欢迎您申请试用体验, 我们会在 5 个工作日左右短信通知您申请结果,感谢您的支持与关注!

欢迎试用体验 ACS:https://survey.aliyun.com/apps/zhiliao/cI5zaVVCs

相关链接:

[1] 社区的参考案例

https://github.com/thijsvanloef/palworld-server-docker/blob/main/charts/palworld/README.md

[2] OpenKruiseGame

https://openkruise.io/zh/kruisegame/introduction/

点击此处,申请试用 ACS。

这篇关于极致成本,如何基于容器计算服务 ACS 打造企业级幻兽帕鲁私服 SaaS 服务?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/691003

相关文章

【区块链 + 人才服务】可信教育区块链治理系统 | FISCO BCOS应用案例

伴随着区块链技术的不断完善,其在教育信息化中的应用也在持续发展。利用区块链数据共识、不可篡改的特性, 将与教育相关的数据要素在区块链上进行存证确权,在确保数据可信的前提下,促进教育的公平、透明、开放,为教育教学质量提升赋能,实现教育数据的安全共享、高等教育体系的智慧治理。 可信教育区块链治理系统的顶层治理架构由教育部、高校、企业、学生等多方角色共同参与建设、维护,支撑教育资源共享、教学质量评估、

poj 1113 凸包+简单几何计算

题意: 给N个平面上的点,现在要在离点外L米处建城墙,使得城墙把所有点都包含进去且城墙的长度最短。 解析: 韬哥出的某次训练赛上A出的第一道计算几何,算是大水题吧。 用convexhull算法把凸包求出来,然后加加减减就A了。 计算见下图: 好久没玩画图了啊好开心。 代码: #include <iostream>#include <cstdio>#inclu

uva 1342 欧拉定理(计算几何模板)

题意: 给几个点,把这几个点用直线连起来,求这些直线把平面分成了几个。 解析: 欧拉定理: 顶点数 + 面数 - 边数= 2。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#inc

uva 11178 计算集合模板题

题意: 求三角形行三个角三等分点射线交出的内三角形坐标。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <stack>#include <vector>#include <

XTU 1237 计算几何

题面: Magic Triangle Problem Description: Huangriq is a respectful acmer in ACM team of XTU because he brought the best place in regional contest in history of XTU. Huangriq works in a big compa

【区块链 + 人才服务】区块链集成开发平台 | FISCO BCOS应用案例

随着区块链技术的快速发展,越来越多的企业开始将其应用于实际业务中。然而,区块链技术的专业性使得其集成开发成为一项挑战。针对此,广东中创智慧科技有限公司基于国产开源联盟链 FISCO BCOS 推出了区块链集成开发平台。该平台基于区块链技术,提供一套全面的区块链开发工具和开发环境,支持开发者快速开发和部署区块链应用。此外,该平台还可以提供一套全面的区块链开发教程和文档,帮助开发者快速上手区块链开发。

K8S(Kubernetes)开源的容器编排平台安装步骤详解

K8S(Kubernetes)是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。以下是K8S容器编排平台的安装步骤、使用方式及特点的概述: 安装步骤: 安装Docker:K8S需要基于Docker来运行容器化应用程序。首先要在所有节点上安装Docker引擎。 安装Kubernetes Master:在集群中选择一台主机作为Master节点,安装K8S的控制平面组件,如AP

基于 YOLOv5 的积水检测系统:打造高效智能的智慧城市应用

在城市发展中,积水问题日益严重,特别是在大雨过后,积水往往会影响交通甚至威胁人们的安全。通过现代计算机视觉技术,我们能够智能化地检测和识别积水区域,减少潜在危险。本文将介绍如何使用 YOLOv5 和 PyQt5 搭建一个积水检测系统,结合深度学习和直观的图形界面,为用户提供高效的解决方案。 源码地址: PyQt5+YoloV5 实现积水检测系统 预览: 项目背景

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip