使用 kruiseGame 进行云原生游戏
你在学习Golang相关的知识吗?本文《使用 kruiseGame 进行云原生游戏》,主要介绍的内容就涉及到,如果你想提升自己的开发能力,就不要错过这篇文章,大家要知道编程理论基础和实战操作都是不可或缺的哦!
什么是克鲁斯游戏?
kruise-game 是 openkruise 旗下的一个开源项目,旨在为游戏工作负载(即游戏服务器)带来云原生转型。
但是游戏服务器到底是什么?
游戏服务器基本上是虚拟机或容器,处理 pvp 多人在线游戏后端的核心功能
下面我展示了现代 pvp 在线游戏使用的基本游戏服务器架构
为什么我们真的需要克鲁斯游戏。默认的 k8s 资源不足以满足游戏工作负载吗?
现代 pvp 游戏变得越来越复杂,例如,它们需要多个游戏服务器来处理不同类型的服务。
现代 pvp 游戏(例如 valorant)需要游戏服务器进行游说、配对,以及运行实际游戏逻辑和管理游戏状态的服务器。处理如此多的游戏服务器是一项艰巨的任务,无法手动完成。那么现在怎么办?
我们有 kubernetes 来拯救。k8s 具有自动化操作和管理
功能可以为我们处理这个负担,只需部署您的游戏服务器映像,我们就完成了,对吗?不是真的
我希望事情这么简单。问题是你没有在这里部署常用的无状态 web 应用程序。游戏服务器不同,它们的要求也不同。k8s 默认资源适合无状态应用程序,但游戏服务器有更复杂的生命周期,它们是有状态的,而且它们的网络要求也不同。
首先,游戏服务器需要直接无损连接到客户端(udp 连接),为此我们需要 pod 的固定 ip 地址,k8s pod 的 ip 在删除、缩放期间会更改。
如果将 pod 用于游戏服务器,您也缺乏对 pod 的控制,有一种称为滚动更新的东西,您可以更新游戏服务器的某些实例来测试更新,并逐渐推广到其他实例防止停机,k8s 调度程序不知道您正在使用游戏服务器,它会以随机方式更新 pod,基本上您无法控制游戏服务器的更新策略。所以您对游戏服务器更新几乎没有灵活性。
为了缓解这些问题,kruise-game 定义了两个专门为游戏服务器工作负载设计的自定义资源 gameserver 和 gameserverset
gameserver:指对指定游戏服务器进行运维和管理操作的抽象。主要用于游戏服务器的更新顺序控制、状态控制、游戏服务器网络变更等运维和管理操作。
gameserverset:指一组游戏服务器生命周期管理的抽象。主要用于副本数量管理、游戏服务器启动等生命周期控制。
kruise-game 提供的游戏服务器管理功能:-
基于镜像的热更新和配置的热重载
更新、删除、隔离指定游戏服务器
内置多种网络模型(固定ip地址和端口、无损直连、全球加速)
自动缩放
自动化运维(服务质量)
独立于云服务提供商
复杂的游戏服务器编排
下图展示了 kruise-game 在 k8s 上的部署架构
开始玩克鲁斯游戏:0
- 获取 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
有关 kruise-game 的更多信息和详细信息,请参阅 kruise-game 文档。
感谢您的阅读,希望您喜欢这个:)。
今天带大家了解了的相关知识,希望对你有所帮助;关于Golang的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

- 上一篇
- 国家烟草专卖局:建立全国统一的电子烟交易管理平台,同一规格产品实行全国统一售价

- 下一篇
- 如何使用 IDE 调试 Java 函数中的错误
-
- Golang · Go教程 | 14分钟前 |
- Golang用WaitGroup控制goroutine执行方法
- 342浏览 收藏
-
- Golang · Go教程 | 16分钟前 |
- GolangHTTP限流与并发控制方法
- 298浏览 收藏
-
- Golang · Go教程 | 17分钟前 |
- Golang日志记录与格式化方法解析
- 431浏览 收藏
-
- Golang · Go教程 | 25分钟前 |
- JupyterNotebook配置Go内核教程
- 248浏览 收藏
-
- Golang · Go教程 | 38分钟前 |
- Golang正则替换与匹配技巧详解
- 124浏览 收藏
-
- Golang · Go教程 | 45分钟前 |
- Golang自定义错误使用技巧详解
- 421浏览 收藏
-
- Golang · Go教程 | 47分钟前 |
- Go语言逐行读取命令输出方法
- 355浏览 收藏
-
- Golang · Go教程 | 50分钟前 | HTTP Go
- GolangHTTP客户端与服务器处理全解析
- 323浏览 收藏
-
- Golang · Go教程 | 50分钟前 |
- Go语言路径与源码定位解析
- 183浏览 收藏
-
- Golang · Go教程 | 53分钟前 |
- Golang并发竞争检测与修复技巧
- 292浏览 收藏
-
- Golang · Go教程 | 1小时前 |
- Go语言集成OAuth2认证指南
- 312浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 499次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- PandaWiki开源知识库
- PandaWiki是一款AI大模型驱动的开源知识库搭建系统,助您快速构建产品/技术文档、FAQ、博客。提供AI创作、问答、搜索能力,支持富文本编辑、多格式导出,并可轻松集成与多来源内容导入。
- 325次使用
-
- AI Mermaid流程图
- SEO AI Mermaid 流程图工具:基于 Mermaid 语法,AI 辅助,自然语言生成流程图,提升可视化创作效率,适用于开发者、产品经理、教育工作者。
- 1106次使用
-
- 搜获客【笔记生成器】
- 搜获客笔记生成器,国内首个聚焦小红书医美垂类的AI文案工具。1500万爆款文案库,行业专属算法,助您高效创作合规、引流的医美笔记,提升运营效率,引爆小红书流量!
- 1135次使用
-
- iTerms
- iTerms是一款专业的一站式法律AI工作台,提供AI合同审查、AI合同起草及AI法律问答服务。通过智能问答、深度思考与联网检索,助您高效检索法律法规与司法判例,告别传统模板,实现合同一键起草与在线编辑,大幅提升法律事务处理效率。
- 1140次使用
-
- TokenPony
- TokenPony是讯盟科技旗下的AI大模型聚合API平台。通过统一接口接入DeepSeek、Kimi、Qwen等主流模型,支持1024K超长上下文,实现零配置、免部署、极速响应与高性价比的AI应用开发,助力专业用户轻松构建智能服务。
- 1210次使用
-
- Golangmap实践及实现原理解析
- 2022-12-28 505浏览
-
- 试了下Golang实现try catch的方法
- 2022-12-27 502浏览
-
- 如何在go语言中实现高并发的服务器架构
- 2023-08-27 502浏览
-
- go和golang的区别解析:帮你选择合适的编程语言
- 2023-12-29 502浏览
-
- 提升工作效率的Go语言项目开发经验分享
- 2023-11-03 502浏览