Redis学习笔记-统计该如何选择数据类型

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介: Redis学习笔记-统计该如何选择数据类型

在业务场景中经常需要统计,如某直播累计观看人数、独立访客人数、历史总观看人数等等,再比如要统计某学生某月的签到情况等,遇到统计的情况,就需要思考如何合理地选择 Redis 数据类型,这篇文章学习一下各种统计的业务场景和分类,这样就能很容易的对应各种统计需求了。


1.笔记图

2.Redis 聚合统计

2.1 场景

  • 交集统计:统计多个集合的共有元素
  • 差集统计:统计一个集合相比于另一个集合有车别的元素
  • 并集统计:统计多个集合的所有元素

2.2 举例

  • 记录所有登录过的用户ID

  • 记录某天所有登录过的用户ID
  • 记录某天新增的用户ID:如记录 14 日和 15 日所有用户 ID,求它们差集合就是新增用户,求差集命令:
SDIFFSTORE user_new user_id_20200804 user_id_20200803

Tips:表示将 user_id_20200804 集合和 user_id 集合求差集,并保存至 user_new 集合中,可表示 20200804 这个日期的新增用户数。

  • 记录某天留存下的用户ID:如记录 14 日和 15 日所有用户 ID,然后求它们交集就是当日留存用户,求交集命令:
SINTERSTORE user_new user_id_20200804 user_id_20200803

Tips:表示将 user_id_20200804 集合和 user_id 集合求交集,并保存至 user_new 集合中,可表示 20200804 留存的用户数。

2.3 优化建议

  • Set 的差集、并集和交集的计算复杂度较高,直接执行这些计算,会导致 Redis 实例阻塞
  • 可以从主从集群中选择一个从库,让它专门负责聚合计算,或者是把数据读取到客户端,在客户端来完成聚合统计

3.排序统计举例

  • 获取最新评论列表:按评论时间的先后给每条评论设置一个权重值,然后再把评论保存到 Sorted Set
ZRANGEBYSCORE comments N-9 N

4.二值状态

  • 统计 ID 3000 的用户在 2020 年 8 月份的签到情况:
  • 统计 ID 3000 的用户在 2020 8 月份的签到情况
SETBIT uid_sign_3000_202008 2 1
  • 检查该用户 8 3 日是否签到
GETBIT uid_sign_3000_202008 2
  • 统计该用户在 8 月份的签到次数
BITCOUNT uid_sign_3000_202008
  • 如果记录了 1 亿个用户 10 天的签到情况,你有办法统计出这 10 天连续签到的用户总数吗?:

  • 把每天的日期作为 key,每个 key 对应一个 1 亿位的 Bitmap,每一个 bit 对应一个用户当天的签到情况
  • 10Bitmap 操作,得到的结果也是一个 Bitmap
  • BITCOUNT 统计下 Bitmap 中的 1 的个数,这就是连续签到 10 天的用户总数了

5.基数统计举例

  • 统计某个网页一天的独立访客(UV)HyperLogLog
  • PFCOUNT uv_20180808
  • PFADD uv_20180808 user1 user2 user3 user4 user5
  • 统计结果是有一定误差的,标准误算率是 0.81%,但是它非常节省空间

6.各个数据类型统计

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
6天前
|
存储 监控 NoSQL
Redis HyperLogLog: 高效统计大数据集的神秘利器
Redis HyperLogLog: 高效统计大数据集的神秘利器
|
6天前
|
存储 消息中间件 NoSQL
Redis数据类型详解:选择合适的数据结构优化你的应用
Redis数据类型详解:选择合适的数据结构优化你的应用
|
6天前
|
存储 算法 NoSQL
探秘HyperLogLog:Redis中的基数统计黑科技
探秘HyperLogLog:Redis中的基数统计黑科技
128 0
|
6天前
|
存储 NoSQL BI
Redis 实战篇:巧用 Bitmap 实现亿级海量数据统计
Redis 实战篇:巧用 Bitmap 实现亿级海量数据统计
69 0
|
6天前
|
存储 NoSQL 关系型数据库
【Redis】Redis的特性和应用场景 · 数据类型 · 持久化 · 数据淘汰 · 事务 · 多机部署
【Redis】Redis的特性和应用场景 · 数据类型 · 持久化 · 数据淘汰 · 事务 · 多机部署
16 0
|
6天前
|
NoSQL Redis 数据库
Redis中的常用命令非常丰富,涵盖了各种数据类型的基本操作以及服务器管理和维护的相关指令
【5月更文挑战第15天】Redis常用命令包括通用(如PING、SELECT)、键操作(KEYS、EXISTS、DEL)、字符串(SET、GET)、哈希(HSET、HGET)、列表(LPUSH、LPOP)、集合(SADD、SMEMBERS)和有序集合(ZADD、ZRANGE)等。这些命令用于数据操作及服务器管理,满足不同场景需求。了解更多命令,建议参考Redis官方文档。
17 2
|
6天前
|
SQL NoSQL Java
Redis数据类型 Hash Set Zset Bitmap HyperLogLog GEO
Redis数据类型 Hash Set Zset Bitmap HyperLogLog GEO
18 0
|
6天前
|
存储 NoSQL 定位技术
Redis常用数据类型及常用命令
这些是Redis中常用的数据类型和命令。Redis还提供了许多其他命令和功能,用于数据存储、操作和查询。你可以根据需要选择适当的数据类型和命令来满足你的应用程序需求。
26 4
|
6天前
|
存储 SQL NoSQL
Redis入门到通关之五大基本数据类型及其使用场景
Redis入门到通关之五大基本数据类型及其使用场景
17 0
|
6天前
|
存储 NoSQL Redis
第十八章 Redis查看配置文件和数据类型
第十八章 Redis查看配置文件和数据类型
22 0