Redis BitMap 用户签到

在这里插入图片描述

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.mzph.cn/news/898501.shtml

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

相关文章

Spring Boot 3 新特性实战:从理论到实践

引言 Spring Boot 自发布以来,凭借其简洁的配置和强大的功能,迅速成为 Java 开发者的首选框架。随着 Spring Boot 3 的发布,开发者们迎来了更多令人兴奋的新特性。本文将深入探讨 Spring Boot 3 的新特性,并通过实战示例展示如何…

Nodejs使用redis

框架:koa,通过koa-generator创建 redis: 本地搭建,使用默认帐号,安装说明地址以及默认启动设置:https://redis.io/docs/latest/operate/oss_and_stack/install/install-redis/install-redis-on-linux/ 中间件&#x…

调研报告:Hadoop 3.x Ozone 全景解析

Ozone 是 Hadoop 的分布式对象存储系统,具有易扩展和冗余存储的特点。 Ozone 不仅能存储数十亿个不同大小的对象,还支持在容器化环境(比如 Kubernetes)中运行。 Apache Spark、Hive 和 YARN 等应用无需任何修改即可使用 Ozone。Ozone 提供了 Java API、S3 接口和命令行接口…

AI学习——卷积神经网络(CNN)入门

作为人类,我们天生擅长“看”东西:一眼就能认出猫狗、分辨红绿灯、读懂朋友的表情……但计算机的“眼睛”最初是一片空白。直到卷积神经网络(CNN)​的出现,计算机才真正开始理解图像。今天,我们就用最通俗的…

除自身以外数组的乘积——面试经典150题(力扣)

题目 给你一个整数数组 nums,返回 数组 answer ,其中 answer[i] 等于 nums 中除 nums[i] 之外其余各元素的乘积 。 题目数据 保证 数组 nums之中任意元素的全部前缀元素和后缀的乘积都在 32 位 整数范围内。 请 不要使用除法,且在 O(n) 时…

⭐算法OJ⭐二叉树的前序遍历【树的遍历】(C++实现)Binary Tree Preorder Traversal

⭐算法OJ⭐二叉树的中序遍历【树的遍历】(C实现)Binary Tree Inorder Traversal Given the root of a binary tree, return the preorder traversal of its nodes’ values. Example 1: Input: root [1,null,2,3] Output: [1,2,3]Explanation: Exam…

计算机二级MS之Excel

声明:跟着大猫和小黑学习随便记下一些笔记供大家参考,二级考试之前将持续更新,希望大家二级都能轻轻松松过啦,过了二级的大神也可以在评论区留言给点建议,感谢大家!! 文章目录 考题难点&#x…

【Linux】VMware Workstation Pro 17 安装教程

目录 安装 VMware Workstation Pro 17 一、CDS Repository 获取安装包 二、网盘获取安装包 三、Broadcom官方获取安装包 后续安装过程没啥特殊要求 安装 VMware Workstation Pro 17 目前VMware Workstation pro 17已经对个人用户免费开放使用。 Broadcom官网地址&#x…

如何在云端平台上建立 30,000 名用户的网页 MMO游戏环境-2 (服务器)

接续上一篇「如何在云端平台上建立 30,000 名用户的网页 MMO游戏环境」,接下来讨论模拟连结上的问题。 最初计划使用35台伺服器来完成这个实验,希望能够有大量的用户连接,以验证真实的连接状况。然而,我们高估了这方面&#xff0c…

架构设计的灵魂交响曲:系统设计各维度的深度解析与实战指南

引言: 系统设计的背景与重要性 在快速变化的技术环境中,数字化转型成为企业生存与发展的核心驱动力。系统设计能力不仅是技术团队的核心竞争力,也是推动业务创新和提升整体效率的关键因素。根据Gartner的研究,超过70%的数字化转型项目未能实…

C语言指针(详细总结)

目录 1.初始C指针 几个重要的概念: 指针的加减 &与* 二级指针 2.指针与数组 指针数组 数组指针变量 一维数组与二维数组传参的本质 ​编辑​编辑 ​编辑 3.指针与函数 函数指针数组 4.指针与结构体 5.野指针以及常见的内存管理错误 常见的内存错…

JAVA学习-练习试用Java实现“编写一个Spark程序,结合Elasticsearch对大数据进行全文搜索和筛选“

问题: 编写一个Spark程序,结合Elasticsearch对大数据进行全文搜索和筛选。 解答思路: 为了编写一个结合Apache Spark和Elasticsearch进行全文搜索和筛选的程序,你需要按照以下步骤操作: 1. 设置Spark环境:…

VLLM专题(二十一)—分布式推理与服务

1. 如何决定分布式推理策略? 在深入探讨分布式推理和服务之前,我们首先需要明确何时使用分布式推理以及可用的策略是什么。常见的做法如下: 单 GPU(无需分布式推理): 如果你的模型可以放入单个 GPU 中,那么你可能不需要使用分布式推理。直接使用单个 GPU 运行推理即可。…

torcharrow gflags版本问题

问题描述 其实仍然是很简单的编译问题,但是又弄了一整个下午加几乎整个晚上,进度缓慢,又吸取了教训,因而还是来记录一下。 在试图使用torcharrow进行推荐系统模拟的时候,撰写的python程序报错:ERROR: flag…

介绍一下TiDB、RocksDb、levelDB、LSM 树、SSTable。

LSM 树(Log-Structured Merge-Tree) 核心原理:通过将随机写转换为顺序写优化写入性能,适用于写密集型场景。数据首先写入内存中的 MemTable(有序结构,如跳表),当达到阈值后转为 Imm…

ESP32 BLE 初步学习笔记

前言 蓝牙作为一个庞大的知识体系,其学习和运用对于初学者来说显得有些复杂且凌乱。我整理了这段时间的学习笔记,涵盖了协议栈、工作流程、参数等内容。在实际应用中,我们主要使用 GAP 和 GATT,协议栈中的其他部分只需了解即可。…

dfs(二十四)47. 全排列 II

47. 全排列 II 给定一个可包含重复数字的序列 nums ,按任意顺序 返回所有不重复的全排列。 示例 1: 输入:nums [1,1,2] 输出: [[1,1,2],[1,2,1],[2,1,1]]示例 2: 输入:nums [1,2,3] 输出:[[1,…

代码随想录算法训练营第五十二天 |101. 孤岛的总面积102. 沉没孤岛103. 水流问题104.建造最大岛屿

101. 孤岛的总面积 卡码网:101. 孤岛的总面积(opens new window) 题目描述 给定一个由 1(陆地)和 0(水)组成的矩阵,岛屿指的是由水平或垂直方向上相邻的陆地单元格组成的区域,且完全被水域单…

Simple-BEV的bilinear_sample 作为view_transformer的解析,核心是3D-2D关联点生成

文件路径models/view_transformers 父类 是class BiLinearSample(nn.Module)基于https://github.com/aharley/simple_bev。 函数解析 函数bev_coord_to_feature_coord的功能 将鸟瞰图3D坐标通过多相机(针孔/鱼眼)内外参投影到图像特征平面&#xff0…

A/B测试入门指南

目录 一、什么是A/B测试1.1 A/A测试1.2 多变量测试 二、A/B测试应用场景三、A/B测试基本流程四、A/B测试面试真题4.1 【是什么】4.2 【为什么】4.3 【怎么做】 五、应用实战 一、什么是A/B测试 A/B 测试是一种常见的实验方法,用于比较两个或多个方案的效果&#xff…