如何在云端平台上建立 30,000 名用户的网页 MMO游戏环境-2 (服务器)

接续上一篇「如何在云端平台上建立 30,000 名用户的网页 MMO游戏环境」,接下来讨论模拟连结上的问题。

最初计划使用35台伺服器来完成这个实验,希望能够有大量的用户连接,以验证真实的连接状况。然而,我们高估了这方面,最终我们只维护了26台核心伺服器以及东京和法兰克福的一台边缘伺服器。


接下来,这些是用来模拟真实连接的机器人伺服器。如图所示,每5分钟,他们收到24GB的数据,但只发送了337MB。这与游戏客户端接收超过传输的典型情况一致。在大规模拥塞实验中,发送和接收资料之间的差异可能高达 8 倍。 CPU 使用率始终维持在 98% 以上。虽然我们的伺服器采用了第三代 AMD EPYC 4C8T 处理器,但我们的机器人程式可能没有得到适当的最佳化,我们仍在寻找有问题的部分。结果,每个伺服器的连线数从最初的 2400 个减少到 1760 个。

接下来,关于边缘伺服器,我们使用了第三代 AMD EPYC 2C4T 处理器。影像显示了接收机器人连接的伺服器的数据。我们控制每个边缘伺服器来处理 2000 个机器人连线。数据方面,每5分钟,每台伺服器接收490MB数据,发送13GB数据。资料包处理数量为每 5 分钟接收 3,000k 个资料包,发送 5,500k 个资料包。 CPU 使用率约为55%。在我们正在进行的测试中,我们计划增加连接数量以验证最大负载。然而在这个过程中,我们遇到了意外中断的问题。

为了优化我们的网路以进行 TCP WebSocket 连接,我们采用了以下设定:

net.core.default_qdisc=fq

net.ipv4.tcp_congestion_control=bbr

网.ipv4.tcp_fastopen=3

net.ipv4.tcp_abort_on_overflow=0

net.ipv4.tcp_notsent_lowat=16384

net.ipv4.tcp_syncookies=1

net.ipv4.tcp_tw_reuse=1

net.ipv4.tcp_timestamps=1

net.ipv4.tcp_fin_timeout=10

net.ipv4.tcp_keepalive_time=600

net.ipv4.tcp_keepalive_probes=3

net.ipv4.tcp_keepalive_intvl=30

net.ipv4.tcp_max_syn_backlog=8192

网.ipv4.tcp_max_tw_buckets=16384

net.ipv4.tcp_window_scaling=1

网.ipv4.tcp_sack=1

网.ipv4.tcp_fack=0

网路.ipv4.tcp_mem=8388608 12582912 16777216

网路.ipv4.tcp_rmem=8192 262411 8388608

网路位址:

net.ipv4.tcp_reordering=5

net.ipv4.tcp_slow_start_after_idle=0

核心.msgmnb=65535

核心.msgmax=65535

net.core.rmem_max=8388608

净.核心.wmem_max=8388608

但是tcp_mem、tcp_rmem 和 tcp_wmem 的设定导致了问题。由于机器人伺服器最初 CPU 超载,资料包无法顺利处理。由于伺服器设定了较大的资料包缓冲区,导致核心记忆体不足,系统以「记忆体不足」错误终止该进程。最终我们删除了这些设置,因为不可以让伺服器受到客户端影响而产生中断。

但奇怪的是,在我们之前对以「G」开头的平台进行的测试中,我们运行了 60,000 个机器人连接,接收 3,000 个连接的边缘伺服器每分钟仅传输了 900 MiB 的数据。相比之下,在这个平台上大约有2,000个连接,数据流量每分钟高达2.5 GB,这显示出明显的差异。
(续)

马上进来看:

https://demo.mb-funs.com/

ps.  ios手機開網頁跑多人3D可能因為記憶體限制踢掉

回馈与申请代码:https://wj.qq.com/s2/18654558/0558/

如果本文对你有帮助,欢迎点赞/关注获取更多技术解析!

也欢迎留下  开发中遇到问题  或是  应用面向 ?

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/898492.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

架构设计的灵魂交响曲:系统设计各维度的深度解析与实战指南

引言: 系统设计的背景与重要性 在快速变化的技术环境中,数字化转型成为企业生存与发展的核心驱动力。系统设计能力不仅是技术团队的核心竞争力,也是推动业务创新和提升整体效率的关键因素。根据Gartner的研究,超过70%的数字化转型项目未能实…

C语言指针(详细总结)

目录 1.初始C指针 几个重要的概念: 指针的加减 &与* 二级指针 2.指针与数组 指针数组 数组指针变量 一维数组与二维数组传参的本质 ​编辑​编辑 ​编辑 3.指针与函数 函数指针数组 4.指针与结构体 5.野指针以及常见的内存管理错误 常见的内存错…

JAVA学习-练习试用Java实现“编写一个Spark程序,结合Elasticsearch对大数据进行全文搜索和筛选“

问题: 编写一个Spark程序,结合Elasticsearch对大数据进行全文搜索和筛选。 解答思路: 为了编写一个结合Apache Spark和Elasticsearch进行全文搜索和筛选的程序,你需要按照以下步骤操作: 1. 设置Spark环境:…

VLLM专题(二十一)—分布式推理与服务

1. 如何决定分布式推理策略? 在深入探讨分布式推理和服务之前,我们首先需要明确何时使用分布式推理以及可用的策略是什么。常见的做法如下: 单 GPU(无需分布式推理): 如果你的模型可以放入单个 GPU 中,那么你可能不需要使用分布式推理。直接使用单个 GPU 运行推理即可。…

torcharrow gflags版本问题

问题描述 其实仍然是很简单的编译问题,但是又弄了一整个下午加几乎整个晚上,进度缓慢,又吸取了教训,因而还是来记录一下。 在试图使用torcharrow进行推荐系统模拟的时候,撰写的python程序报错:ERROR: flag…

介绍一下TiDB、RocksDb、levelDB、LSM 树、SSTable。

LSM 树(Log-Structured Merge-Tree) 核心原理:通过将随机写转换为顺序写优化写入性能,适用于写密集型场景。数据首先写入内存中的 MemTable(有序结构,如跳表),当达到阈值后转为 Imm…

ESP32 BLE 初步学习笔记

前言 蓝牙作为一个庞大的知识体系,其学习和运用对于初学者来说显得有些复杂且凌乱。我整理了这段时间的学习笔记,涵盖了协议栈、工作流程、参数等内容。在实际应用中,我们主要使用 GAP 和 GATT,协议栈中的其他部分只需了解即可。…

dfs(二十四)47. 全排列 II

47. 全排列 II 给定一个可包含重复数字的序列 nums ,按任意顺序 返回所有不重复的全排列。 示例 1: 输入:nums [1,1,2] 输出: [[1,1,2],[1,2,1],[2,1,1]]示例 2: 输入:nums [1,2,3] 输出:[[1,…

代码随想录算法训练营第五十二天 |101. 孤岛的总面积102. 沉没孤岛103. 水流问题104.建造最大岛屿

101. 孤岛的总面积 卡码网:101. 孤岛的总面积(opens new window) 题目描述 给定一个由 1(陆地)和 0(水)组成的矩阵,岛屿指的是由水平或垂直方向上相邻的陆地单元格组成的区域,且完全被水域单…

Simple-BEV的bilinear_sample 作为view_transformer的解析,核心是3D-2D关联点生成

文件路径models/view_transformers 父类 是class BiLinearSample(nn.Module)基于https://github.com/aharley/simple_bev。 函数解析 函数bev_coord_to_feature_coord的功能 将鸟瞰图3D坐标通过多相机(针孔/鱼眼)内外参投影到图像特征平面&#xff0…

A/B测试入门指南

目录 一、什么是A/B测试1.1 A/A测试1.2 多变量测试 二、A/B测试应用场景三、A/B测试基本流程四、A/B测试面试真题4.1 【是什么】4.2 【为什么】4.3 【怎么做】 五、应用实战 一、什么是A/B测试 A/B 测试是一种常见的实验方法,用于比较两个或多个方案的效果&#xff…

自己构建的交叉编译器找不到PATH_MAX

接上篇centos6.10 编译gcc11.5 x64到aarch64交叉工具链 -CSDN博客 PATH_MAX找不到,不仅在编译gcc的过程中遇到,而且临时改gcc源码添加#define PATH_MAX 4096 宏定义后勉强通过gcc全量编译。这个新的gcc编译使用了PATH_MAX宏的代码还是会找不到。这个问题…

vscode查看文件历史git commit记录

方案一:GitLens 在vscode扩展商店下载GitLens 选中要查看的文件,vscode界面右上角点击GitLens的图标,选择Toggle File Blame 界面显示当前打开文件的所有修改历史记录 鼠标放到某条记录上,可以看到记录详情,选中O…

ngx_http_conf_ctx_t

定义在 src/http/ngx_http_config.h typedef struct {void **main_conf;void **srv_conf;void **loc_conf; } ngx_http_conf_ctx_t; ngx_http_conf_ctx_t 是 Nginx 中用于管理 HTTP 配置上下文的核心结构体,其设计体现了 Nginx 多级配置&…

IREE AI编译器编译测试流程指南

iree onnx demo 计划协议系列博客,记录学习iree编译器的过程. 今天第一篇博客,记录安装和测试iree 文章目录 iree onnx demo下载安装ireepython环境安装编译测试1. [前端] onnx模型转MLIR文件2. [后端] MLIR文件转可执行文件3. [执行] 执行测试编译后的文件 关于后端设备的介…

【产品小白】如何运营一个新的产品

运营一个新产品既充满机遇,也伴随着挑战。新产品运营的核心在于快速获取用户、验证市场假设、持续迭代与优化,并通过有效的推广和用户反馈机制不断完善产品。 1. 市场调研与定位 用户调研:在产品初期,通过访谈、问卷、竞品分析等…

破解验证码新利器:基于百度OCR与captcha-killer-modified插件的免费调用教程

破解验证码新利器:基于百度OCR与captcha-killer-modified插件的免费调用教程 引言 免责声明: 本文提供的信息仅供参考,不承担因操作产生的任何损失。读者需自行判断内容适用性,并遵守法律法规。作者不鼓励非法行为,保…

JSON 解析中需要清理的危险字符

在代码中 replace(chr(0), "") 的作用是删除 JSON 响应中可能存在的空字符(Null character)。以下是详细解释: 1. chr(0) 是什么? chr(0) 表示 ASCII 码为 0 的字符,即空字符(Null Character&am…

指令系统2(Load/Store 指令)

一. Load/Store 指令 1. 前变址 前变址指令是在读取或存储数据时,先根据基址寄存器(Rn)与偏移量(offset)计算出有效地址,再进行数据操作。相关指令及示例如下: LDR R0, [R1, #4]:从…

ubuntu部署运行xinference全精度对话deepseek本地部署图文教程

前置环境搭建劳请移步往期 source activate 自己环境名启动python3.12环境安装xinference, 按教程敲命令,wheel包与wsl的通用,pip install 包名。 vllm引擎,transform引擎也会顺带自动装上了。 后续操作请参照往期教程。本地部署模…