Go游戏服务器开发的一些思考(三十):排行榜服务器设计思路

排行方式

通常有2类排行:

  • 全服所有人排名
  • 前N名排名

考虑到大量用户的情况下,实时全服排名难度很大,一般可以做成离线排名的方式。

这里考察的是大量用户的情况下,前N名的实时排名方法。

背景假设

这里假设,有500万玩家同时在线

那么极端情况下,每秒500万玩家可能同时改变战力值

初步设计

这里写图片描述

  1. 启动时,加载最新前N名排名数据。
  2. 变化的战力输入到排序服务,通过排序器,更新排名。并最终保存到数据库。
  3. 排名服务内置 战力数据缓冲器。每秒500万次排序,不一定能够完成。因此需要做缓冲。且缓冲规模最大在500w数据。
  4. 大多数情况下的战力变化,实际上只做了一次比较。这点很重要。

以上基本可以做到接近实时的排名。

但是,还存在问题。一般的服务器网络模块每秒接收数据次数在10万级别。

因此上述单个排名服务是无法胜任上述背景假设的。

再次设计

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

fananchong2

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值