首页 > 数据库 >GaussDB(for Redis)游戏实践:玩家下线行为上报

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

时间:2023-09-18 10:36:59浏览次数:42  
标签:__ 过期 通知 GaussDB Redis key 上报 下线

本文分享自华为云社区《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,Redis,key,上报,下线
From: https://www.cnblogs.com/huaweiyun/p/17710942.html

相关文章

  • 深入探讨Spring Boot中的Redis缓存
    介绍Redis是一种高性能的内存数据库,常用于缓存和消息队列等场景。在SpringBoot中,我们可以通过集成Redis来实现缓存功能。本文将深入探讨SpringBoot中的Redis缓存,包括如何配置、如何使用以及一些注意事项。配置在SpringBoot中,我们可以通过在application.properties或applicati......
  • 【GO使用redis】GO语言使用Redis基础
    之前我为大家分享了php版本的对于redis的使用,当然我也是一个go的初学者,把自己在用go的时候对接redis的时候也记录一下,为大家分享一下。下面正式开始。redis有许多go语言的客户端包,都能实现对redis的操作。例如redigo、go-redis。我们可以随意选择想要安装的我们使用的是redigo,下......
  • Redis主从架构环境搭建(一主二从 + 3个sentinel)
    安装RedisServersudoadd-apt-repositoryppa:redislabs/redissudoaptupdatesudoaptinstallredis-serverredis-cli-h127.0.0.1-p6379pingsudosystemctlrestartredis-serverss-an|grep6379redis-server-vRedisserverv=7.0.12sha=00000000:0malloc=jem......
  • 【红包雨功能的】环境部署(弹性伸缩、负载均衡、Redis读写分离、云服务器部署)
    创建环境创建专用网络VPC安全组创建云服务器打包部署2.Java环境#下载jdk17wgethttps://download.oracle.com/java/17/latest/jdk-17_linux-x64_bin.tar.gz#安装上传工具以后使用命令rz选中文件进行上传yuminstall-ylrzsz#解压tar-xzvfjdk-17_linux-x64_b......
  • SpringBoot Redis使用AOP防止重复提交
    自定义注解importjava.lang.annotation.ElementType;importjava.lang.annotation.Retention;importjava.lang.annotation.RetentionPolicy;importjava.lang.annotation.Target;/***@ProjectName:gswr-ets-cloud*@ClassName:*@Description:防止重复提交的自定义......
  • redis该怎么用
    最近一些人在介绍方案时,经常会出现redis这个词,于是很多小伙伴百度完redis也就觉得它是一个缓存,然后项目里面把数据丢进去完事,甚至有例如将实体属性拆分塞进redishash里面的奇怪用法等等!原因是什么呢?大家觉得redis火,使用了redis项目就是高大上的,于是不管三七二十一,项目里用上强塞一......
  • Redis急速说明
    Redis急速部署前言:需求的出现在Web应用发展的初期,那时关系型数据库受到了较为广泛的关注和应用,原因是因为那时候Web站点基本上访问和并发不高、交互也较少。而在后来,随着访问量的提升,使用关系型数据库的Web站点多多少少都开始在性能上出现了一些瓶颈,而瓶颈的源头一般是在磁盘......
  • 在CentOS上安装Redis-cli工具
    如果你想在CentOS上安装Redis-cli工具,可以按照以下步骤进行操作:1.安装Redis依赖包:在命令行中执行以下命令安装Redis依赖包:```sudoyuminstallgccmake```2.下载Redis源代码包:从Redis官网(https://redis.io/download)下载最新的Redis源代码包。3.解压源代码包:将下载的Redis......
  • SpringBoot + Redis + Token 解决接口幂等性问题
    前言SpringBoot实现接口幂等性的方案有很多,其中最常用的一种就是token+redis方式来实现。下面我就通过一个案例代码,帮大家理解这种实现逻辑。原理前端获取服务端getToken()->前端发起请求->header中带上token->服务端校验前端传来的token和redis中的token是否......
  • 【心得】TP6使用Redis进行处理商城秒杀
    书接上回,上次分享了TP6对于Redis的基础使用,那么今天就为大家带来一个简单的,使用场景很高的心得代码风险,Redis在商城秒杀的使用,该代码为简单分享能解决一些基础后续可以根据自己所需进行业务重构。读这篇文章的我就默认大家已经环境都安装好了,如果不知道怎么安装的可以传送到这里......