redis中bitmap应用

原理介绍

Redis Bitmap 是 Redis 中的一种数据结构,它类似于位图,可以用来表示一组二进制位,每个二进制位只能是 0 或 1。Redis Bitmap 提供了一些操作命令,如 SETBIT、GETBIT、BITCOUNT 等,可以对位图进行设置、获取和计数等操作。

在Redis 中,可以把Bitmaps想象成一个以比特位为单位的数组,数组的每个单元只能存储0和1,数组的下标在Bitmaps 中叫做偏移量。

BitMap 在 Redis 中并不是一个新的数据类型,其底层是 Redis 实现。Redis 其实只支持 5 种数据类型,并没有 BitMap 这种类型,BitMap 底层是基于 Redis 的字符串类型实现的。

BitMap占用的空间,就是底层字符串占用的空间。假如BitMap偏移量的最大值是OFFSET_MAX,那么它底层占用的空间就是︰

8*1024*1024*512 = 2^32

由于C语言中字符串的末尾都要存储一位分隔符,所以实际上BitMap的offset值上限是︰

2^32-1

适用场景

  1. 用户在线状态:可以使用一个位图来表示用户的在线状态,每个用户对应一个二进制位,如果该位为 1,则表示该用户在线;如果该位为 0,则表示该用户离线。通过 SETBIT 命令可以将某个用户的在线状态设置为 1 或 0,通过 BITCOUNT 命令可以统计在线用户的数量。

  2. 签到系统:可以使用一个位图来表示用户的签到情况,每个二进制位表示一天,如果该位为 1,则表示该用户在该天签到过;如果该位为 0,则表示该用户在该天未签到。通过 SETBIT 命令可以将某个用户在某天的签到状态设置为 1,通过 BITCOUNT 命令可以统计某个用户累计签到的天数。

  3. 统计 UV 和 PV:可以使用一个位图来表示用户的访问情况,每个二进制位表示一天,如果该位为 1,则表示该天有用户访问过网站;如果该位为 0,则表示该天没有用户访问过网站。通过 SETBIT 命令可以将某个用户在某天的访问状态设置为 1,通过 BITCOUNT 命令可以统计某段时间内的 UV 和 PV 数量。

  4. 过滤器:可以使用一个位图来表示一组元素的存在情况,每个二进制位表示一个元素,如果该位为 1,则表示该元素存在;如果该位为 0,则表示该元素不存在。通过 SETBIT 命令可以将某个元素的存在状态设置为 1,通过 GETBIT 命令可以查询某个元素是否存在。

  5. 统计活跃用户:使用日期key,用户ID为offset,当日活跃就设置为1。可统计连续多天登录等情况。

相关推荐
运维行者_11 分钟前
企业无线网络监控的挑战与智能化演进趋势
大数据·运维·服务器·网络·数据库
IT二叔13 分钟前
Java项目部署-03-teamcity-cicd-docker镜像流水线方式部署
java·ci/cd·持续部署
一路向北he29 分钟前
字节钢铁军团--“提供情境,而非控制”
java·开发语言·前端
国强_dev1 小时前
技术探讨:使用 stunnel 加密转发数据库连接时,如何获取客户端真实 IP?
数据库·网络协议·tcp/ip
@insist1231 小时前
系统规划与管理师-信息系统规划核心工作要点解析
数据库·软考·系统规划与管理师·软件水平考试·系统规划与管理工程师
超级数据查看器1 小时前
超级数据查看器 v10.0 发布
java·大数据·数据库·sqlite·安卓
数安3000天1 小时前
增量数据如何自动分类分级,避免目录“过期“?
大数据·数据库
折哥的程序人生 · 物流技术专研2 小时前
《Java 100 天进阶之路》第50篇:阻塞队列与并发容器(2026版)
java·面试题·java进阶·blockingqueue·并发容器·集合源码·java100天进阶
ai_coder_ai2 小时前
编写自动化脚本,在自己后端服务中使用Open Api进行设备相关操作
java·运维·自动化
南墙上的石头2 小时前
麒麟 V10 重装人大金仓 V8R6 踩坑实录(含 MySQL 兼容模式)
数据库·mysql