参考答案
一、Redis的5个基本数据类型
- String
- Hash
- List
- Set
- SortedSet
二、Redis基本数据类型的特性、使用场景
1. String
这是最简单的类型,即普通的 set 和 get,做简单的 KV 缓存。
String的实际应用场景:
- 缓存功能:String字符串是最常用的数据类型,不仅仅是Redis,各个语言都是最基本类型,因此,利用Redis作为缓存,配合其它数据库作为存储层,利用Redis支持高并发的特点,可以大大加快系统的读写速度、以及降低后端数据库的压力。
- 计数器:许多系统都会使用Redis作为系统的实时计数器,可以快速实现计数和查询的功能。而且最终的数据结果可以按照特定的时间落地到数据库或者其它存储介质当中进行永久保存。
- 共享用户Session:用户重新刷新一次界面,可能需要访问一下数据进行重新登录,或者访问页面缓存Cookie,但是可以利用Redis将用户的Session集中管理,在这种模式只需要保证Redis的高可用,每次用户Session的更新和获取都可以快速完成。大大提高效率。
2. Hash
这个是类似 Map 的一种结构,可以将结构化的数据,例如一个对象给缓存在 Redis 里(前提是这个对象没嵌套其他的对象),然后每次读写缓存的时候,可以就操作 Hash 里的某个字段。
3. List
List 是有序列表,它在很多场景中都可以用到。
例如:
- 通过 List 存储一些列表型的数据结构,类似粉丝列表、文章的评论列表。
- 通过 lrange 命令,读取某个闭区间内的元素,可以基于 List 实现分页查询,这个是很棒的一个功能,基于 Redis 实现简单的高性能分页,可以做类似微博那种下拉不断分页的东西,性能高,就一页一页走。
- 搞个简单的消息队列,从 List 头怼进去,从 List 屁股那里弄出来。
List本身就是我们在开发过程中比较常用的数据结构了,热点数据更不用说了。
- 消息队列:Redis的链表结构,可以轻松实现阻塞队列,可以使用左进右出的命令组成来完成队列的设计。比如:数据的生产者可以通过Lpush命令从左边插入数据,多个数据消费者,可以使用BRpop命令阻塞的“抢”列表尾部的数据。
- 文章列表或者数据分页展示的应用。例如,我们常用的博客网站的文章列表,当用户量越来越多时,而且每一个用户都有自己的文章列表,而且当文章多时,都需要分页展示,这时可以考虑使用Redis的列表,列表不但有序同时还支持按照范围内获取元素,可以完美解决分页查询功能。大大提高查询效率。
4. Set
Set 是无序集合,可自动去重。
- 直接基于 Set 将系统里需要去重的数据扔进去,就可自动去重了。如果需要对一些数据进行快速的全局去重,也可基于 JVM 内存里的HashSet 进行去重;但是如果某个系统部署在多台机器上,那么就要基于Redis进行全局的 Set 去重。
- 可以基于 Set 玩儿交集、并集、差集的操作,例如交集,我们可以把两个人的好友列表整一个交集,看看俩人的共同好友是谁。
这些场景比较多,因为对比很快,操作也简单,两个查询一个Set搞定。
5. Sorted Set
Sorted set 是排序的 Set,去重但可以排序,写进去的时候给一个分数,自动根据分数排序。
有序集合的使用场景与集合类似,但是set集合不是自动有序的,而Sorted set可以利用分数进行成员间的排序,而且是插入时就排序好。
所以,当你需要一个有序且不重复的集合列表时,可以选择Sorted set数据结构作为选择方案。
- 排行榜:有序集合经典使用场景。例如视频网站需要对用户上传的视频做排行榜,榜单维护可能是多方面:按照时间、按照播放量、按照获得的赞数等。
- 用Sorted Sets来做带权重的队列,比如普通消息的score为1,重要消息的score为2,然后工作线程可以选择按score的倒序来获取工作任务。让重要的任务优先执行。
以上,是Redis面试题【Redis有哪些基本数据类型,都有哪些特性,以及使用场景】的参考答案。
输出,是最好的学习方法。
欢迎在评论区留下你的问题、笔记或知识点补充~
—end—