Redis BitMap 用户签到

news2025/3/21 20:29:00

在这里插入图片描述

Redis Bitmap

Bitmap(位图)是 Redis 提供的一种用于处理二进制位(bit)的特殊数据结构,它基于 String 类型,每个 bit 代表一个布尔值(0 或 1),可以用于存储大规模的二值状态数据,如签到、活跃用户统计、去重等。


1. Bitmap 基本原理

  • Bitmap 本质上是一个二进制数组,每个 bit 仅占 1 位,相比普通的 String 存储方式(每个字符 8 位),能大幅节省空间。
  • Redis 并没有单独的数据类型 Bitmap,它是基于 String 结构的。
  • 通过 位运算SETBITGETBITBITCOUNTBITOP 等)高效存取数据。

2. Bitmap 常用命令

(1)SETBIT:设置某一位的值

SETBIT key offset value
  • key:键名
  • offset:bit 偏移量(从 0 开始)
  • value01

📌 示例

SETBIT user:1001 1 1  # 将 user:1001 的第 1 位设置为 1
SETBIT user:1001 2 0  # 将 user:1001 的第 2 位设置为 0
SETBIT user:1001 5 1  # 将 user:1001 的第 5 位设置为 1

假设 user:1001 初始状态是:(每个 0 代表 1 bit,总共 32 bit = 4 字节)

00000000 00000000 00000000 00000000

执行:

SETBIT user:1001 5 1  # 将 user:1001 的第 5 位设置为 1
SETBIT user:1001 5 1

结果变成:

00000100 00000000 00000000 00000000

第 5 位(从 0 开始计数,即第 6 个 bit)被设置为 1。

作用:类似于一个布尔数组,可用于表示某个用户在不同时间点的状态(如签到)。


(2)GETBIT:获取某一位的值

GETBIT key offset
  • key:键名
  • offset:bit 偏移量

📌 示例

GETBIT user:1001 1  # 返回 1
GETBIT user:1001 2  # 返回 0
GETBIT user:1001 5  # 返回 1

作用:查询某个状态,如某用户是否签到。


(3)BITCOUNT:统计 bit 为 1 的个数

BITCOUNT key [start end]
  • key:键名
  • [start end](可选):字节范围(默认统计整个 key)

📌 示例

BITCOUNT user:1001  # 统计 user:1001 中 bit 为 1 的个数

作用

  • 统计某个用户的签到次数
  • 统计一段时间内活跃用户数量

(4)BITOP:对多个 Bitmap 进行位运算

BITOP operation destKey key1 key2 ...
  • operation
    • AND(与)
    • OR(或)
    • XOR(异或)
    • NOT(非)
  • destKey:存储结果的 key
  • key1 key2 ...:参与运算的 key

📌 示例

BITOP AND active_users today yesterday  # 统计连续两天都活跃的用户
BITOP OR total_active day1 day2 day3    # 统计三天内活跃过的用户

作用

  • 计算多天签到的交集、并集
  • 统计活跃用户

3. Bitmap 典型应用

(1)用户签到

场景:每个用户有一个 31 位的 Bitmap(对应 31 天),bit 为 1 表示已签到,0 表示未签到。

📌 示例

SETBIT sign:1001:20240301 0 1  # 用户 1001 在 3 月 1 日签到
SETBIT sign:1001:20240302 1 1  # 3 月 2 日签到
SETBIT sign:1001:20240303 2 1  # 3 月 3 日签到
GETBIT sign:1001:20240303 2  # 查询 3 月 3 日是否签到(返回 1)
BITCOUNT sign:1001:202403  # 查询用户 1001 3 月签到次数

(2)统计活跃用户

场景:每天创建一个 Bitmap,记录活跃用户(bit 位置对应用户 ID)。

📌 示例

SETBIT active:20240301 1001 1  # 用户 1001 3 月 1 日活跃
SETBIT active:20240301 1002 1  # 用户 1002 3 月 1 日活跃
SETBIT active:20240302 1002 1  # 用户 1002 3 月 2 日活跃
BITCOUNT active:20240301  # 统计 3 月 1 日活跃用户数
BITOP AND active_both active:20240301 active:20240302  # 统计连续两天活跃的用户

(3)A/B 测试 & 用户权限控制

场景:用 Bitmap 存储用户是否属于 A/B 测试组或是否拥有某个权限。

📌 示例

SETBIT experiment:groupA 1001 1  # 用户 1001 参与 A 组测试
SETBIT experiment:groupB 1002 1  # 用户 1002 参与 B 组测试
GETBIT experiment:groupA 1001  # 查询用户 1001 是否在 A 组

4. Bitmap 优势

节省空间:1 个 bit 仅占 1/8 字节,非常适合存储大规模用户数据(如千万级别用户签到情况)。
高效查询GETBITSETBIT 操作时间复杂度O(1),快速读写。
支持批量运算BITCOUNTBITOP 等可进行高效统计


5. Bitmap 限制

不支持删除某个 bit(只能置 0,无法真正删除)。
不支持范围查询(需要配合 BITCOUNTGETBIT)。
偏移量有限制(Redis 最大 String 长度约 512MB,即支持 2^32 个 bit)。


6. 总结

功能命令作用
设置 bitSETBIT key offset value设置指定偏移量的 bit
获取 bitGETBIT key offset获取指定偏移量的 bit
统计 1 的数量BITCOUNT key统计 key 中 bit 为 1 的个数
位运算BITOP operation destKey key1 key2对多个 Bitmap 进行 AND/OR/XOR/NOT 运算

Bitmap 非常适合用于海量用户数据的布尔状态存储,如签到、活跃用户、权限控制等场景。

参考文献

[1] https://redis.io/docs/latest/develop/data-types/bitmaps/

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2319158.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

未来办公与生活的新范式——智慧园区

在信息化与智能化技术飞速发展的今天,智慧园区作为一种新兴的城市发展形态,正逐步成为推动产业升级、提升城市管理效率、改善居民生活质量的重要力量。智慧园区不仅融合了先进的信息技术,还深刻体现了可持续发展的理念,为园区内的…

Hugging Face预训练GPT微调ChatGPT(微调入门!新手友好!)

Hugging Face预训练GPT微调ChatGPT(微调入门!新手友好!) 在实战中,⼤多数情况下都不需要从0开始训练模型,⽽是使⽤“⼤⼚”或者其他研究者开源的已经训练好的⼤模型。 在各种⼤模型开源库中,最…

【CSS3】化神篇

目录 平面转换平移旋转改变旋转原点多重转换缩放倾斜 渐变线性渐变径向渐变 空间转换平移视距旋转立体呈现缩放 动画使现步骤animation 复合属性animation 属性拆分逐帧动画多组动画 平面转换 作用:为元素添加动态效果,一般与过渡配合使用 概念&#x…

Unity音频混合器如何暴露参数

音频混合器是Unity推荐管理音效混音的工具,那么如何使用代码对它进行管理呢? 首先我在AudioMixer的Master组中创建了BGM和SFX的分组,你也可以直接用Master没有问题。 这里我以BGM为例,如果要在代码中进行使用就需要将参数暴露出去…

如何理解分布式光纤传感器?

关键词:OFDR、分布式光纤传感、光纤传感器 分布式光纤传感器是近年来备受关注的前沿技术,其核心在于将光纤本身作为传感介质和信号传输介质,通过解析光信号在光纤中的散射效应,实现对温度、应变、振动等物理量的连续、无盲区、高…

PMP-项目运行环境

你好!我是 Lydia-穎穎 ♥感谢你的陪伴与支持 ~~~ 欢迎一起探索未知的知识和未来,现在lets go go go!!! 1. 影响项目的要素 项目存在在不同的环境下,环境对于项目的交付产生不同的影响。需了解环境对于项目的影响,采取相应措施应对…

shell 脚本搭建apache

#!/bin/bash # Set Apache version to install ## author: yuan# 检查外网连接 echo "检查外网连接..." ping www.baidu.com -c 3 > /dev/null 2>&1 if [ $? -eq 0 ]; thenecho "外网通讯良好!" elseecho "网络连接失败&#x…

Huawei 鲲鹏(ARM/Aarch64)服务器安装KVM虚拟机(非桌面视图)

提出问题 因需要进行ARM架构适配,需要在Huawei Taishan 200k(CPU: Kunpeng 920 5231K)上,创建几台虚拟机做为开发测试环境。 无奈好久没搞了,看了一下自己多年前写的文章:Huawei 鲲鹏&#xf…

《Python实战进阶》No28: 使用 Paramiko 实现远程服务器管理

No28: 使用 Paramiko 实现远程服务器管理 摘要 在现代开发与运维中,远程服务器管理是必不可少的一环。通过 SSH 协议,我们可以安全地连接到远程服务器并执行各种操作。Python 的 Paramiko 模块是一个强大的工具,能够帮助我们实现自动化任务&…

【Kafka】深入了解Kafka

集群的成员关系 Kafka使用Zookeeper维护集群的成员信息。 每一个broker都有一个唯一的标识,这个标识可以在配置文件中指定,也可以自动生成。当broker在启动时通过创建Zookeeper的临时节点把自己的ID注册到Zookeeper中。broker、控制器和其他一些动态系…

C++特性——RAII、智能指针

RAII 就像new一个需要delete,fopen之后需要fclose,但这样会有隐形问题(忘记释放)。RAII即用对象把这个过程给包起来,对象构造的时候,new或者fopen,析构的时候delete. 为什么需要智能指针 对于…

CentOS系类普通挂载磁盘挂载命令

检查磁盘是否有分区 lsblk如果 vdb 下面没有分区(比如 vdb1),你需要先创建分区。 创建分区(如果需要) fdisk /dev/vdb然后在 fdisk 交互界面: 输入 n 创建新分区 选择 p 创建主分区 默认分区号和大小 输…

强化学习(赵世钰版)-学习笔记(9.策略梯度法)

本章是课程的导数第二章,旨在讲解策略的函数化形式。 之前的方法,描述一个策略都是用表格的形式,每一行代表一个状态,每一列代表一个行为,表格中的元素对应相关状态下执行相关行为的概率。 函数化的策略表征形式是指&a…

【c++】【STL】unordered_set 底层实现(简略版)

【c】【STL】unordered_set 底层实现&#xff08;简略版&#xff09; ps:这个是我自己看的不保证正确&#xff0c;觉得太长的后面会总结整个调用逻辑 unordered_set 内部实现 template <class _Kty, class _Hasher hash<_Kty>, class _Keyeq equal_to<_Kty>…

网络安全设备配置与管理-实验4-防火墙AAA服务配置

实验4-p118防火墙AAA服务配置 从这个实验开始&#xff0c;每一个实验都是长篇大论&#x1f613; 不过有好兄弟会替我出手 注意&#xff1a;1. gns3.exe必须以管理员身份打开&#xff0c;否则ping不通虚拟机。 win10虚拟机无法做本次实验&#xff0c;必须用学校给的虚拟机。首…

【论文阅读】Contrastive Clustering Learning for Multi-Behavior Recommendation

论文地址&#xff1a;Contrastive Clustering Learning for Multi-Behavior Recommendation | ACM Transactions on Information Systems 摘要 近年来&#xff0c;多行为推荐模型取得了显著成功。然而&#xff0c;许多模型未充分考虑不同行为之间的共性与差异性&#xff0c;以…

基于协同过滤推荐算法的景点票务数据系统(python-计算机毕设)

摘 要 I ABSTRACT II 第 1 章 引言 1 研究背景及意义 1 研究背景 1研究意义 1 国内外研究现状 2 智慧旅游 3旅游大数据 3 研究内容 4本章小结 4 第 2 章 相关技术概述 5 基于内容的推荐算法 5 基于内容的推荐算法原理 5基于内容的推荐算法实现 5 协同过滤推荐算法 6 协同过…

Ubuntu 24 常用命令方法

文章目录 环境说明1、账号管理1.1、启用 root 2、包管理工具 apt & dpkg2.1、apt 简介 & 阿里源配置2.2、dpkg 简介2.3、apt 和 dpkg 两者之间的关系2.4、常用命令 3、启用 ssh 服务4、防火墙5、开启远程登录6、关闭交换分区7、build-essential&#xff08;编译和开发软…

Flask多参数模版使用

需要建立目录templates&#xff1b; 把建好的html文件放到templates目录里面&#xff1b; 约定好参数名字&#xff0c;单个名字可以直接使用&#xff1b;多参数使用字典传递&#xff1b; 样例&#xff1a; from flask import render_template # 模板 (Templates) #Flask 使用…

自然语言处理|深入解析 PEGASUS:从原理到实践

一、引言 在信息爆炸的时代&#xff0c;互联网上的文本数据以极快的速度增长。无论是新闻资讯、学术论文、社交媒体动态&#xff0c;还是各类报告文档&#xff0c;我们每天接触到的文字信息量巨大。如何快速、准确地提取关键内容成为一项重要任务。文本摘要技术通过将长篇文本…