Redis常用数据结构以及其应用场景–学习笔记
Redis五种数据结构类型应用场景总结
一、String类型应用场景
1、单值缓存
2、对象缓存
3、分布式锁
4、计数器:如文章阅读量
5、Web集群session共享
6、分布式ID
二、Hash结构
1、对象缓存
2、电商购物车:对于购物车的增删改查操作
Hash结构优点
(1)同类数据归类整合储存,方便数据管理
(2)相比string操作消耗内存与cpu更小
(3)相比string储存更节省空间
Hash结构缺点
(1)过期功能不能使用在field上,只能用在key上
(2)Redis集群架构下不适合大规模使用
三、List应用场景
1、常用数据结构
Stack(栈) = LPUSH + LPOP
Queue(队列)= LPUSH + RPOP
Blocking MQ(阻塞队列)= LPUSH + BRPOP
2、微博和微信公号消息流
四、Set应用场景
1、微信抽奖小程序
1)点击参与抽奖加入集合
SADD key {userlD}
2)查看参与抽奖所有用户
SMEMBERS key
3)抽取count名中奖者
SRANDMEMBER key [count] / SPOP key [count]
2、微信微博点赞,收藏,标签
- 点赞
SADD like:{消息ID} {用户ID} - 取消点赞
SREM like:{消息ID} {用户ID} - 检查用户是否点过赞
SISMEMBER like:{消息ID} {用户ID} - 获取点赞的用户列表
SMEMBERS like:{消息ID} - 获取点赞用户数
SCARD like:{消息ID}
3、集合操作实现微博微信关注模型
4、集合操作实现电商商品筛选
五、ZSet有序集合结构
Zset集合操作实现排行榜
1)点击新闻
ZINCRBY hotNews:20190819 1 守护香港
2)展示当日排行前十
ZREVRANGE hotNews:20190819 0 9 WITHSCORES
3)七日搜索榜单计算
ZUNIONSTORE hotNews:20190813-20190819 7
hotNews:20190813 hotNews:20190814… hotNews:20190819
4)展示七日排行前十
ZREVRANGE hotNews:20190813-20190819 0 9 WITHSCORES
结尾
本文章仅作为个人学习笔记展示,如有不对,欢迎指正修改,谢谢。