游戏之登录排队系统及防刷

前言

不管什么游戏,只要用户达到限制的上限或饥饿营销,都要用到排队系统

游戏的登录排队机制,其实就是 服务的限流 、削峰机制

为什么要限流

1>改善玩家体验,优化游戏的流畅度,减少玩家的卡顿延迟等

2>服务器承载力(带宽,CPU,IO,内存,UDB等等),需要考虑最优性价比

3>平滑流量波动,需要考虑新服与非新服 玩家人数差异,优化软硬件成本(云服务器有些资源不能更改或下降)

4>应对高并发情况 面对数百万级别的预约玩家,排队机制能够有效地控制开服初期的高峰流量

5>风险管控(鸡蛋不能都放到一个篮子里)防止外挂和恶意攻击,同理 ( 特别是单机服)

1:登录流程(这里以手游为例)

(1)手游一般通过SDK 到平台验证

(2)把平台返回的类TOKEN与类UID加渠道号 发送到登录/验证/账号 服务器,

(3) 登录/验证/账号服务器 去平台验证下,可以返回TOKEN 及附加信息

(3*)这步可有可无, 也可以发送服务器列表/列表的URL地址 /URL部分地址 (可以不由登录服务器返回,由请求其他服务完成)

(4)选服务器登录 (选择角色)(看游戏类型,这步可能也没有)

(5)登录gate 或 直接登录game srv

2:排队服(单独服务器)

1>如果MMO 建议放再 4 到5间,无需破环原来的流程,中间插入 一个排队服,前端 只需要多链接一次即可,不需要排队时,撤销即可

2>如果全区全服 还是一直要有排队服的,主要是的限流 、削峰,可以在登录前线排队,也可以放到登录后

3:登录优化

可以采用无状态服务器 处理 ,增强并发行

可以参考 加解密验证用户的合法性

问题:

1> 单位时间内,像 同服 发多次消息呢?

自己挤自己,这也可以的吧

2>如果是 不同服呢

可能需要以类试 redis这样,记录下 状态了,不同服 去redis查看状态,干挤就挤

4:消息防刷

1>增加流水号,

2>增加消息的数字摘要 (MD5,SHA等),一般MD5足够用了

3> 为了减少消息体量,数字摘要 可以取 中间部分 有个4-8位就够了(像MD5 32 TO MD5 16 一样)( MD5加密后的位数有两种类型:16位与32位,默认使用32位。16位实际上是从32位字符串中取中间的第9位到第24位的部分), 约定好就可以了

4>再加强版 就是 压缩了,前端过来的压缩(感觉真到这步,绝对是设计有问题了,代价需要这么大么)
5:防加速

(1):前端自行检测

请求网络时间或从后端得一个时间(N1),记录当前系统时间(C1),再记录一个流逝时间(D1)

任意时间检测 先获取一个流逝时间(D2),再获取当前系统时间(C2),再获取一个N2

设定一定范围 误差 ( O)

D2 -D1 > N2-N1 + ( O) 使用加速外挂了(加速齿轮,可以加速本地时间的流逝)

C2 -C1 > N2-N1 + ( O) ,本地时间被加速了

C2 -C1 >D2 -D1+ ( O) ,本地加速到了

(2)后端检查

检查消息的合理性

复制代码
 可以增加内存日志系统(复盘用)
 可以参考  https://www.cnblogs.com/JefferyZhou/archive/2010/07/07/1773220.html

6:如果觉得有用,麻烦点个赞,加个收藏

相关推荐
运筹vivo@14 小时前
leetcode每日一题: 跳跃游戏 IV
leetcode·游戏·宽度优先
sheeta199817 小时前
LeetCode 每日一题笔记 日期:2026.05.18 题目:1345. 跳跃游戏 IV
笔记·leetcode·游戏
德迅云安全-小潘17 小时前
游戏行业面临的网络安全挑战
安全·web安全·游戏
游乐码18 小时前
Unity基础(一)游戏中的数学Mathf函数
游戏·unity·游戏引擎
blackorbird1 天前
M4 MacBook Air外接RTX 5090实现3A游戏与AI加速
人工智能·游戏
Android出海1 天前
5月合规风暴眼:Google Play权限大限与欧盟游戏监管新棋局
人工智能·游戏·google play·谷歌开发者·android开发者·google开发者·google play开发者
STDD1 天前
Teeworlds / DDNet 服务器搭建:经典 2D 竞技平台游戏
服务器·游戏·github
小豪GO!1 天前
我的MC猎人游戏记录
游戏
2601_950316062 天前
2026 最新 Switch 游戏合集+SWITCH模拟器
游戏
御水流红叶2 天前
Android-Unity游戏逆向思路
android·游戏·unity