文章目录
数据结构模型
Redis提供的Bitmaps这个“数据结构”可以实现对位的操作。Bitmaps本身不是一种数据结构,实际上就是字符串,但是它可以对字符串的位进行操作。
可以把Bitmaps想象成一个以位为单位数组,数组中的每个单元只能存0或者1,数组的下标在bitmaps中叫做偏移量。单个bitmaps的最大长度是512MB,即2^32个比特位。
bitmaps的常用指令
1.setbit
创建或给已经存在的bitmaps类型的key指定偏移量(offset)位置上设置对应的值(只能是0或者1)
setbit key offset value
2.getbit
获取指定偏移量(offset)上的值(0或者1)
getbit key offset
3.bitcount
获取当前key指定范围内的1的数量
bitcount key [start] [end]
4.bitop
Bitmaps间的运算,跟二进制的运算一样,有交,并,非,异或操作,并将结果保存到指定的destkey(destination key)中
bitop and/or/not/xor destkey key[key…]
bitmaps命令案例
setbit与getbit
bitcount案例
bitop运算
bitmaps的应用场景
统计活跃用户数
将每个用户的id对应bitmaps上的一个下标,通过对活跃用户对应的位进行置位,就能用一个value记录所有的活跃用户信息。
假如我们有如下场景:
需要统计N天内访问网站的用户,连续N天访问网站的用户。
解决方案:
我们将每天访问网站的用户存储在一个bitmaps中,通过日期生成键,例如:unique:users:2017-07-11,这样我们就可以统计每天的用户访问情况,同时通过bitmaps的与或运算等功能统计出一个时间段内的活跃用户及连续N天访问网站用户等相关需求。