首页 后端开发 Golang 使用 kruiseGame 进行云原生游戏

使用 kruiseGame 进行云原生游戏

Sep 03, 2024 pm 02:17 PM

什么是克鲁斯游戏?

kruise-game 是 openkruise 旗下的一个开源项目,旨在为游戏工作负载(即游戏服务器)带来云原生转型。

但是游戏服务器到底是什么?
游戏服务器基本上是虚拟机或容器,处理 PVP 多人在线游戏后端的核心功能

下面我展示了现代 PvP 在线游戏使用的基本游戏服务器架构

Cloud Native gaming with kruiseGame

为什么我们真的需要克鲁斯游戏。默认的 k8s 资源不足以满足游戏工作负载吗?

现代 PvP 游戏变得越来越复杂,例如,它们需要多个游戏服务器来处理不同类型的服务。
现代 PvP 游戏(例如 valorant)需要游戏服务器进行游说、配对,以及运行实际游戏逻辑和管理游戏状态的服务器。处理如此多的游戏服务器是一项艰巨的任务,无法手动完成。那么现在怎么办?

我们有 kubernetes 来拯救。K8s 具有自动化操作和管理
功能可以为我们处理这个负担,只需部署您的游戏服务器映像,我们就完成了,对吗?不是真的

我希望事情这么简单。问题是你没有在这里部署常用的无状态 Web 应用程序。游戏服务器不同,它们的要求也不同。k8s 默认资源适合无状态应用程序,但游戏服务器有更复杂的生命周期,它们是有状态的,而且它们的网络要求也不同。

  • 首先,游戏服务器需要直接无损连接到客户端(udp 连接),为此我们需要 pod 的固定 IP 地址,k8s pod 的 IP 在删除、缩放期间会更改。

  • 如果将 pod 用于游戏服务器,您也缺乏对 pod 的控制,有一种称为滚动更新的东西,您可以更新游戏服务器的某些实例来测试更新,并逐渐推广到其他实例防止停机,K8s 调度程序不知道您正在使用游戏服务器,它会以随机方式更新 pod,基本上您无法控制游戏服务器的更新策略。所以您对游戏服务器更新几乎没有灵活性。

为了缓解这些问题,kruise-game 定义了两个专门为游戏服务器工作负载设计的自定义资源 gameServergameserverSet

  • gameServer:指对指定游戏服务器进行运维和管理操作的抽象。主要用于游戏服务器的更新顺序控制、状态控制、游戏服务器网络变更等运维和管理操作。

  • gameServerSet:指一组游戏服务器生命周期管理的抽象。主要用于副本数量管理、游戏服务器启动等生命周期控制。

kruise-game 提供的游戏服务器管理功能:-

  • 基于镜像的热更新和配置的热重载

  • 更新、删除、隔离指定游戏服务器

  • 内置多种网络模型(固定IP地址和端口、无损直连、全球加速)

  • 自动缩放

  • 自动化运维(服务质量)

  • 独立于云服务提供商

  • 复杂的游戏服务器编排

下图展示了 kruise-game 在 k8s 上的部署架构

Cloud Native gaming with kruiseGame

开始玩克鲁斯游戏:0

  1. 获取 k8s 集群和 helm

你需要一个 kruise-game 的 k8s 集群,获得 k8s 集群的最简单方法是在你的机器上安装 minikube,同时确保你的机器上安装了 helm。

2.启动 minikube

minikube start 
登录后复制

3.使用helm安装kruise-game

#kruise-game relies on openkruise so you need to install openkruise first
# Firstly add openkruise charts repository if you haven't do this.
$ helm repo add openkruise https://openkruise.github.io/charts/
# [Optional]
$ helm repo update
# Install the latest version.
$ helm install kruise openkruise/kruise --version 1.6.3
#now instakk kruise-game
$ helm install kruise-game openkruise/kruise-game --version 0.8.0
登录后复制

4.转到您的 minikube 仪表板

minikube dashboard 
登录后复制

5.你应该有 kruise-game-system 命名空间,恭喜你安装了 kruise-game

Cloud Native gaming with kruiseGame

有关 kruise-game 的更多信息和详细信息,请参阅 kruise-game 文档。

感谢您的阅读,希望您喜欢这个:)。

以上是使用 kruiseGame 进行云原生游戏的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门文章

仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章

仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶体解释及其做什么(黄色晶体)
1 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章标签

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

Go语言包导入:带下划线和不带下划线的区别是什么? Go语言包导入:带下划线和不带下划线的区别是什么? Mar 03, 2025 pm 05:17 PM

Go语言包导入:带下划线和不带下划线的区别是什么?

如何编写模拟对象和存根以进行测试? 如何编写模拟对象和存根以进行测试? Mar 10, 2025 pm 05:38 PM

如何编写模拟对象和存根以进行测试?

Beego框架中NewFlash()函数如何实现页面间短暂信息传递? Beego框架中NewFlash()函数如何实现页面间短暂信息传递? Mar 03, 2025 pm 05:22 PM

Beego框架中NewFlash()函数如何实现页面间短暂信息传递?

如何使用跟踪工具了解GO应用程序的执行流? 如何使用跟踪工具了解GO应用程序的执行流? Mar 10, 2025 pm 05:36 PM

如何使用跟踪工具了解GO应用程序的执行流?

如何定义GO中仿制药的自定义类型约束? 如何定义GO中仿制药的自定义类型约束? Mar 10, 2025 pm 03:20 PM

如何定义GO中仿制药的自定义类型约束?

Go语言中如何将MySQL查询结果List转换为自定义结构体切片? Go语言中如何将MySQL查询结果List转换为自定义结构体切片? Mar 03, 2025 pm 05:18 PM

Go语言中如何将MySQL查询结果List转换为自定义结构体切片?

Go语言如何便捷地写入文件? Go语言如何便捷地写入文件? Mar 03, 2025 pm 05:15 PM

Go语言如何便捷地写入文件?

我如何使用衬里和静态分析工具来提高GO代码的质量和可维护性? 我如何使用衬里和静态分析工具来提高GO代码的质量和可维护性? Mar 10, 2025 pm 05:38 PM

我如何使用衬里和静态分析工具来提高GO代码的质量和可维护性?

See all articles