Redis常用数据类型及其应用场景
String
字符类型
利用其自增自减运算,从而实现计数器功能
应用场景: 文章阅读量、点赞数和在看数
List
列表类型
List 可以作为一个双向链表,通过 rpush和 lpop 写入和读取消息
应用场景:使用List做异步队列,rpush生产消息,lpop消费消息,当lpop没有消息时,可以sleep一段时间,然后检查有没有消息,或者也可以使用blpop,在没有消息的情况下,一直阻塞直到有消息进来。
Set
无序集合类型
Set 可以实现交集、并集等操作
应用场景:
- 通过sinter命令实现查看共同好友功能;
- 实现抽奖功能,通过sadd命令将用户加入到集合中,再通过spop命令随机弹出指定数量的元素并将其从集合中删除。
ZSet
有序集合类型
是set的增强版本,增加了一个score参数,自动会根据score的值进行排序
应用场景:
-
网站热搜功能:首先点击视频增加播放量、点击量,用zincrby命令来实现,然后再通过zrange命令展示出排行前多少名的热搜。
-
延时队列:使用ZSet,拿时间戳作为score,消息内容作为key调用zadd来生产消息,消费者用zrangebyscore指令获取指定时间之前的数据轮询进行处理。
Hash
散列表类型
一般key为ID或者唯一标示,value对应的就是详情了
应用场景:
- 商品详情,个人详情;
- 购物车,用hset来添加商品,hincrby来增加商品数量,
Bitmap
位图
支持按位来存储信息
应用场景:实现 布隆过滤器(BloomFilter);
HyperLogLog
提供不精确的去重计数功能,比较适合用来做大规模数据的去重统计;
GEO
可以用来保存地理位置,并作位置距离计算等。
应用场景:
-
实现附近的人;
-
计算最优地图路径;