GaussDB(for Redis)游戏实践:玩家下线行为上报

gaussdb,for,redis,游戏,实践,玩家,下线,行为,上报 · 浏览次数 : 16

小编点评

**基于Redis的用户下线上报实现实现用户下线上报能力的常见方式** **1. 使用Redis key过期功能** - 用户登录后,为每一个用户设置一个过期时间(3-5分钟)。 - 游戏客户端,定期每分钟上报一次心跳。 - 若5分钟内,收到心跳,则重置过期时间。 - 若未收到,则将触发key过期,系统判定用户下线。 **2. 使用Redis键空间通知功能** - 用户通过订阅频道或模式,以接收key的修改、过期等通知。 - 键空间通知允许用户通过订阅频道接收键的变更,键事件通知则接收执行命令的变更。 **3. 在有业务流量和无业务流量场景下测试上报延时** **无业务流量收到全部key过期耗时:**9秒9秒 **有业务流量全部key过期耗时:**3分41秒3分44秒 **原理分析** -开源Redis采用惰性删除和定期检查两种策略进行key过期处理。 - 惰性删除在访问的时候进行过期检查,并定期执行任务进行清理。 - 定期检查任务以保证数据库中的key一直处于有效期内。 **总结** - GaussDB(for Redis)是一款超越开源Redis的企业级KV数据库,在游戏场景中,除了被应用在游戏玩家下线场景,还被广泛应用在玩家数据存储、排行榜、好友关系、消息推送等场景中。 - 采用存算分离的架构,既能满足游戏业务对高并发的性能指标要求,又能降本增效。

正文

本文分享自华为云社区《GaussDB(for Redis) 游戏实践:玩家下线行为上报》,作者:GaussDB 数据库

为保护未成年人的身心健康,2007年国家推出网络游戏防沉迷系统,对未成年人的游戏时间进行限制。游戏厂家需要及时感知用户的下线时间并上报。Redis是游戏数据库重要选型之一,在基于开源Redis实现以上功能时,感知用户下线行为延迟大,导致上报时间不准确。华为云GaussDB(for Redis)作为一款企业级游戏数据库,具备卓越的企业级能力,能及时上报用户下线行为,并被广泛应用于排行榜等多种业务场景。

一、基于Redis的用户下线上报实现

实现用户下线上报能力的常见方式

使用Redis key过期功能,结合键空间通知功能可以实现用户下线上报,常见使用方式如下:

1)用户登录后,为每一个用户key设置一个过期时间(3-5分钟)

2)游戏客户端,定期每分钟上报一次心跳。收到心跳后,服务端重置游戏用户key的过期时间

3)为避免网络波动造成的未及时上报,若5分钟内,收到心跳,则重置过期时间;若未收到,将触发key过期,系统判定用户下线。

因此,Redis键空间通知功能要及时感知key过期,以确保上报时间的准确性。

Redis键空间通知功能

Redis键空间通知(keyspace notification),允许用户通过订阅频道或模式, 以接收key的修改、过期等通知。对于每个key的修改,键空间通知都会发送两种不同类型的事件。以DB0用户mykey过期为例,Redis会发送两条消息,相当于执行了两个publish命令:

  • PUBLISH __keyspace@0__:mykey expire
  • PUBLISH __keyevent@0__:expire mykey

通过订阅频道 __keyspace@0__:mykey 可以接收 0 号数据库中所有修改键 mykey 的事件, 而订阅频道 __keyevent@0__:expire 则可以接收 0 号数据库中所有执行 expire 命令的键。其中以 keyspace 为前缀的频道被称为键空间通知,而以 keyevent 为前缀的频道则被称为键事件通知。

可以通过命令CONFIGSET notify-keyspace-events [parameter]来开启或者关闭键空间通知功能,若parameter为空则表示关闭该功能,若不空则开启。通常将参数设置为“AKE”,表示发送所有类型通知。

字符

发送的通知

K

键空间通知,所有通知以 __keyspace@<db>__ 为前缀

E

键事件通知,所有通知以 __keyevent@<db>__ 为前缀

g

DEL 、 EXPIRE 、 RENAME 等类型无关的通用命令的通知

$

字符串命令的通知

l

列表命令的通知

s

集合命令的通知

h

哈希命令的通知

z

有序集合命令的通知

x

过期事件:每当有过期键被删除时发送

e

驱逐(evict)事件:每当有键因为 maxmemory 政策而被删除时发送

A

参数 g$lshzxe 的别名

通过以下命令,可以订阅DB0所有过期的用户key

redis-cli --csv psubscribe '__keyevent@0__:expire'

二、GaussDB(for Redis)与开源Redis key过期键空间通知延时对比

Redis规格:都采用4GB的规格

测试步骤:

1)使用memtier_benchmark预置10w个key

2)使用客户端定期key过期事件

3)使用python脚本,对其中的3w个key设置10s过期时间

4) 分别在有业务流量和无业务流量场景,统计收到3w个key过期的通知耗时

测试结果:

 

无业务流量收到全部key过期耗时

有业务流量全部key过期耗时

GaussDB(for Redis)

9

9

开源Redis

3分41秒

3分44秒

可以看出,在有无业务流量场景下,GaussDB(for Redis)仅需9秒可以完成全部key过期的上报,而社区Redis需要4分钟左右才能完成上报,严重影响用户下线行为上报的准确性。

三、原理分析

开源Redis键空间通知功能采用了惰性删除和定期删除两种策略,即在访问的时候进行过期检查,同时后台以一定频率执行定期检查任务,可以通过修改配置文件redis.conf的hz选项来调整这个频率。每次过期任务会按以下流程进行删除操作:

  1. 从设置了过期时间的key的集合中随机检查20个key。
  2. 删除检查中发现的所有过期key。
  3. 如果检查结果中25%以上的key已过期,则开始新一轮任务。

可以注意到,开源Redis并不是一次运行就检查所有的库中所有的键,而是随机检查一定数量的键,从而导致上报延时长。而GaussDB(for Redis)后台有一个实时线程会对key进行持续扫描,及时上报过期key,也不会影响前台写操作。

四、总结

GaussDB(for Redis)是一款超越开源Redis的企业级KV数据库,在游戏场景中,除了被应用在游戏玩家下线场景,还被广泛应用在玩家数据存储、排行榜、好友关系、消息推送等场景。采用存算分离的架构,既能满足游戏业务对高并发的性能指标要求,又能降本增效,深受游戏开发者的青睐。

点击关注,第一时间了解华为云新鲜技术~

与GaussDB(for Redis)游戏实践:玩家下线行为上报相似的内容:

GaussDB(for Redis)游戏实践:玩家下线行为上报

Redis是游戏数据库重要选型之一,华为云GaussDB(for Redis)能及时上报用户下线行为,被广泛应用于排行榜等多种业务场景。

《迷你世界》亿级玩家都在用的游戏场景推荐系统长啥样?

摘要:通过使用华为云企业级KV数据库GaussDB(for Redis),《迷你世界》的推荐业务不仅成本降低了60%,而且提升了画像数据承载量,让玩家更容易、更快速找到自己喜欢的游戏场景。 本文分享自华为云社区《《迷你世界》亿级玩家都在用的游戏场景推荐系统长啥样?》,作者:GaussDB数据库。 提

聊聊游戏业务怎么用高斯Redis

摘要:其实游戏客户对数据库的诉求是很明确的,数据库应当“放心存放心用”。 本文分享自华为云社区《华为云GaussDB(for Redis)揭秘第27期:聊聊游戏业务怎么用高斯Redis》,作者:高斯Redis官方博客。 华为云数据库团队是比较重视技术洞察的,对客户真实的业务场景也比较看重。年初出差了

GaussDB(for Redis)多租户:读写权限控制和数据库隔离的完美融合

华为云GaussDB(for Redis)很经典的企业级特性是多租户能力,支持添加只读账号、读写账号,并且可约束每个账号可访问的数据库(DB)范围,避免误操作其他租户数据。

揭秘华为云GaussDB(for Redis)丨大key治理

GaussDB(for Redis)提供了完备的大Key解决方案,支持大Key在线诊断、监控预警、承载力强等能力,弥补了开源Redis在大key问题上的不足,让DBA如虎添翼。

数据安全没保证?GaussDB(for Redis)为你保驾护航

摘要:GaussDB (for Redis)通过账号管理、权限隔离、高危命令禁删/重命名、安全IP免密登录、实例回收站等企业级特性,保障用户数据库数据和信息安全。 本文分享自华为云社区《数据安全没保证?GaussDB(for Redis)为你保驾护航》,作者: GaussDB 数据库。 近日,一些用

即时通讯系统为什么选择GaussDB(for Redis)?

摘要:如果你需要一款稳定可靠的高性能企业级KV数据库,不妨试试GaussDB(for Redis)。 每当网络上爆出热点新闻,混迹于各个社交媒体的小伙伴们全都开启了讨论模式。一条消息的产生是如何在群聊中传递的呢?让我们一起来探索即时通讯系统(IM)的原理。 IM系统架构的原理 当你在群聊“相亲相爱一

解读GaussDB(for MySQL)灵活多维的二级分区表策略

本文分享自华为云社区《GaussDB(for MySQL)创新特性:灵活多维的二级分区表策略》,作者:GaussDB 数据库。 背景介绍 分区表及二级分区表的功能,可以让数据库更加有效地管理和查询大规模数据,传统商业数据库具备该能力。MySQL支持分区表,与传统商业数据库相比,MySQL对二级分区表

华为云GaussDB(for Influx)单机版上线,企业降本增效利器来了

GaussDB(for Influx)推出了单机版方案,可用于开发、测试等场景,既能享受到服务化带来的便利,也可以明显地降低使用成本。

从Purge机制说起,详解GaussDB(for MySQL)的优化策略

当前GaussDB(for MySQL)的Purge优化功能,通过任务流水线化、线程优先级调整、二次分发等手段,避免数据库undo log堆积,极大提升Purge的性能,大幅改善用户体验。