ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

剑指 Offer:Redis 的 14 大场景!

2021-03-18 21:53:34  阅读:151  来源: 互联网

标签:缓存 14 zset Offer Redis 列表 帖子 ID


昨天一位网友在面试腾讯中被问到了,Redis 是单线程的,为什么还那么快?他回答的不是很好,而且面试官也善意的提醒了一些关键点,但是由于他没准备,所以再次失败了。

关于这个问题,我其实在一年前就写过这个答案《Redis 是单线程结构,但为何单线程还能支持高并发?》。

今天我们来讨论另外一个关于 Redis 的高频面试题:Redis 的使用场景有哪些?

这个问题其实很套路。第一个回答往往都会是“缓存”。缓存确实是 Redis 使用最多的领域,但是这个回答往往会被面试官引导到其他技术上,比如:Memcache。也或者会问缓存一致性问题。

如果你回答的不是很好,面试官可能会问,Redis 还有哪些使用场景?或者说 Redis 可以用来做什么?

一部分人可能会回答:分布式锁。说到这个,面试官可能就会问,怎么实现?原理是什么?有什么缺陷等,一回头发现自己又跳坑里了。

所以,今天我就抽个一点时间,根据以前我做电商的经验。分享一下 Redis 的 10 大使用场景。

1、记录帖子或者文章的点赞数、评论数和点击数 (hash)。

2、记录用户的帖子 ID 列表 (排序),便于快速显示用户的帖子列表 (zset)。

3、记录帖子的标题、摘要、作者和封面信息,用于列表页展示 (hash)。

4、记录帖子的点赞用户 ID 列表,评论 ID 列表,用于显示和去重计数 (zset)。

5、缓存近期热帖内容 (帖子内容空间占用比较大),减少数据库压力 (hash)。

6、记录帖子的相关文章 ID,根据内容推荐相关帖子 (list)。

7、如果帖子 ID 是整数自增的,可以使用 Redis 来分配帖子 ID(计数器)。

8、收藏集和帖子之间的关系 (zset)。

9、记录热榜帖子 ID 列表,总热榜和分类热榜 (zset)。

10、缓存用户行为历史,进行恶意行为过滤 (zset,hash)。

11、秒杀,抢购(分布式锁)。

12、会话、热点数据(缓存)。

13、收藏商品,聊天,群聊,发布与订阅(pub/sub)。

14、系统解耦,队列(lpush、rpop)。

另外还有一些场景,我没列举到。只要你能回答到上面这些,基本上面试问题不大。但是,我们也要注意,不要刻意的为了使用某一个功能,而故意使用某项技术。比如,Redis 的作者就不推荐在队列等方面使用 Redis 来做。

欢迎在留言区与我分享你的想法,也欢迎你在留言区记录你的思考过程。感谢阅读,如果你觉得这篇文章对你有帮助的话,也欢迎把它分享给更多的朋友。

标签:缓存,14,zset,Offer,Redis,列表,帖子,ID
来源: https://blog.51cto.com/15127565/2664960

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有