Redis 10 位图
概述
Redis 从 2.2 版本增加了 Bitmap(位图)
当需要统计用户一年的某些信息,如活跃或不活跃,登录或不登录,打卡或没打卡。
如果使用普通的 key / value存储,则要记录 365 条记录,如果用户量很大,需要的空间也会很大。
Redis 提供了 Bitmap 位图这种数据结构,Bitmap 就是通过操作二进制位来进行记录,即为 0 和 1。
如果要记录 365 天的打卡情况,使用 Bitmap 表示的形式大概如下:0101000111000111......
这样 365 天相当于 365 bit,又 1 字节 = 8 bit , 所以相当于使用 46 个字节即可。
BitMap 就是通过一个 bit 位来表示某个元素对应的值或者状态,其中的 key 就是对应元素本身。
实际上底层也是通过对字符串的操作来实现的。
赋值
单项赋值
setbit
setbit key offset value
设置 key 的第 offset 位为 value (1 或 0)
使用 bitmap 来记录一周的打卡记录(1 为打卡,0 为没打卡)
127.0.0.1:6379> setbit sign 0 1
(integer) 0
127.0.0.1:6379> setbit sign 1 0
(integer) 0
127.0.0.1:6379> setbit sign 2 0
(integer) 0
127.0.0.1:6379> setbit sign 3 1
(integer) 0
127.0.0.1:6379> setbit sign 4 1
(integer) 0
127.0.0.1:6379> setbit sign 5 0
(integer) 0
127.0.0.1:6379> setbit sign 6 0
(integer) 0
取值
单项取值
getbit
getbit key offset
获取 offset 设置的值,未设置过默认返回 0。
# 查看周四是否打卡
127.0.0.1:6379> getbit sign 3
(integer) 1
# 查看周六是否打卡
127.0.0.1:6379> getbit sign 5
(integer) 0
统计
bitcount
bitcount key [start, end]
统计 key 上位为 1 的个数
统计这周打卡的记录
127.0.0.1:6379> bitcount sign
(integer) 3
只有 3 个值为 1,即只有 3 天是打卡的状态。
参考
https://www.bilibili.com/video/BV1S54y1R7SB?spm_id_from=333.999.0.0
版本
6.2.6
天河有尽身作涯,星海无边前是岸。