一、Bitmaps
Bitmaps本身不是一种新的数据类型,实际上就是字符串,但是它可以对字符串的位进行操作。在Redis中Bitmaps和字符串的操作方法不太相同。可以把Bitmaps想象成一个以位为单位的数组,数组的每个单元只能存储0和1,数组的下标在Bitmaps中叫偏移量。
命令
- setbit设置某个偏移量的值,记录每个独立用户是否访问过网站,是为1,否则为0。users:20210706是2021-07-06这天独立访问用户的bitmaps,如图,表示1、6、10号用户访问过。
注意:很多时候用户的id是以某一个数字开头的,比如10001,直接将用户id和偏移量绑定会造成一定的空间浪费,通常做法是将用户id减去这个数字作为偏移量。
在第一次初始化bitmaps的时候,如果偏移量非常大,那么初始化过程会很缓慢,甚至造成redis的阻塞。 - getbit获得某个偏移量的值、
- countbit获得字符串中被设置为1的个数,通过start和end可以在特定的位上计数
- **bitop and(or/not/xor)**是一个复合操作,可以求多个bitmap的and(交集)、or(并集)、not(非)、xor(异或)将结果保存在destkey中
二、HyperLogLog
用于计算基数的操作,{1,2,3,4,5,5,6,4}基数为6,一共有6个不重复元素。
命令
- pfadd,向hyperloglog中添加数据,相同元素会去重
- pfcount,统计基数个数
- pfmerge,合并多个个hll到一个hll中
三、Geospatial
是地理位置的基本操作
命令
- geoadd,添加地理位置,经度、纬度、名称,有效经度为±180°,有效纬度约为±85°,已经添加的数据无法再次添加
- geopos,获取地点的经纬度
- geodist,获取俩个位置间的直线距离
- georadius,以给定的经纬度为中心,寻找半径内的元素