序
本文主要研究一下 redis 的数据结构的应用
string
最常用的就是 incr 操作,比如可以用来维护用户在某个抽奖活动的剩余抽奖次数
setnx 方法可以用来实现分布式锁
hashmap
可以用来存储 session,作为分布式 session 的一个实现方案
可以用来存储用户购物车,value 值存储的 key 为物品,value 为其数量
set
set 可以用来存储每个标签对应的文章 id
也可以用来存储每个文章的已投票用户 id,通过 add 返回值可以判断该值之前是否已经存在
zset
zset 可以用来存储文章的得票数,使用得票数作为 score,使用 zset 排序得出投票最高的前 N 篇文章
或者用来存储最近登录的用户 id,使用时间作为 score,使用 zset 排序得出最近登录的前 N 个用户 id
也可以存储用户最近浏览的物品,使用时间作为 score,使用 zset 排序得出用户最近浏览的前 N 个物品
也可以存储物品最近浏览的用户,使用时间作为 score,使用 zset 排序得出最近浏览该物品的前 N 个用户
list
可以作为简单的消息队列,通过 list 的 lpush 以及 brpop 作为消息队列的入队及消费的操作
hyperloglog
用来粗略统计网站的每日 UV
geo(底层使用 zset)
使用 geo 来存储 poi 信息,比如存储门店的经纬度,之后可以根据半径查询附件的门店信息
bitmaps(底层是 string 结构)
用来统计用户每日是否登陆过
小结
redis 之所以比 memcache 更为流行主要是由于其强大的数据结构及其提供的操作,丰富的数据结构在特定的场景给我们提供了诸多便利,好好合理利用其数据结构特性,是用好 redis 的前提。
doc
SpringBoot 应用之分布式会话
redis 的 GEO 实战
redis 的 bitset 实战
redis 的 HyperLogLog 实战
Redis 实战 SpringBoot 版本之购物车服务
Redis 实战 SpringBoot 版本之投票服务
聊聊 jesque 在 redis 中的数据结构