前言

  redis作为我们开发的一大神器,我们接触肯定不会少,但是很多同学也许只会存储String类型的值,这是非常不合理的。在这里,将带大家认识Redis的5中数据结构。

1、问:Redis有那些数据结构?

  常见的5种:字符串(String),散列(Hash), 列表(List),集合(Set),有序集合(SortedSet)等;除此之外,还有HyperLogLog、Geo、Pub/Sub。

  :之前项目组也有遇见过 BloomFilter(布隆过滤器),这个能很好地防止缓存穿透的发生,它的原理也很简单,就是利用高效的数据结构和算法快速判断出你这个 Key 是否在数据库中存在,不存在你 Return 就好了,存在你就去查了DB刷新Key、Value,再Return。

  传送门:《防止缓存穿透的神器:BloomFilter》

2、问:Redis的5种数据结构,有哪些最适合的使用场景?

  答:先从String说起吧。

String

  这个是最简单的类型,就是普通的 set 和 get,做简单的 KV 缓存。

  但是真实的开发环境中,很多人可能会把很多比较复杂的结构也统一转成 String 去存储使用,比如有的人他就喜欢把对象或者List 转换为 JSONString 进行存储,拿出来再反序列化。

  这里就不讨论这样做的对错了,但是我们在日常开发中,还是能在最合适的场景使用最合适的数据结构,这也是代码规范的一个表现。

String的适应应用场景比较多

  • 缓存功能:String 字符串是最常用的数据类型,不仅仅是Redis,各个语言都是最基本类型,因此,利用Redis作为缓存,配合其他数据库作为存储层,利用Redis支持高并发的特点,可以大大
    加快系统的读写速度、以及降低后端数据库的压力。
  • 计数器:许多系统都会使用Redis作为系统的实时计数器,可以快速实现计数和查询的功能。而且最终的数据结果可以按照特定的时间落地到数据库或者其他存储介质当中进行永久保存。
  • 共享用户Session:用户重新刷新一次界面,可能需要访问以下数据进行重新登录或者访问页面缓存 Cookie,但是可以利用 Redis 将用户的 Session 集中管理,在这种模式只需要保证Redis的高可用,每次用户Session的更新和获取都可以快速完成,大大提高效率。

Hash:

  这个是类似 Map 的一种结构,这个一般就是可以将结构化的数据,比如一个对象(前提是这个对象没有嵌套其他的对象)给缓存在Redis里,然后每次读写缓存的时候,就可以操作Hash里的某个字段。

  但是这个的场景略为单一,因为现在很多对象都是比较复杂的,比如商品对象里面就包含了很多属性,其中也有对象。

List

  List 是有序列表,这个还是比较常用的。

  比如可以通过List 存储一些列表型的数据,商品的评价列表、粉丝列表之类的东西。

  比如可以通过 lrange 命令,读取某个闭区间内的元素,可以基于 List 实现分页查询,这个是很棒的一个功能,基于 Redis 实现简单的高性能分页,可以做类似微博下拉不断分页的东西,性能高,就一页一页走。

  比如可以搞个简单的消息队列,从List 头怼进去,从 List 屁股那里弄出来。

  List 本身就是我们在开发过程中比较常用的数据结构了,热点数据更不用说了。

  • 消息队列Redis 的链表结构,可以轻松实现阻塞队列,可以使用左进右出的命令组合来完成队列的设计。比如:数据的生产者可以通过 Lpush 命令从左边插入数据,多个数据消费者,可以使用 BRpop 命令阻塞的“抢”列表尾部的数据。
  • 文章列表或者数据分页展示的应用。比如,我们常用的博客网站的文章列表,当用户量越来越多时,而且每一个用户都有自己的文章列表,而且文章多时,都需要分页展示,这时可以考虑使用Redis 的列表,列表不但有序,同时还支持按照范围内获取元素,可以完美解决分页查询功能,大大提高查询效率。

Set:

  Set 时无序集合,会自动去重的那种。

  直接基于 Set 将系统里需要去重的数据扔进去,自动就给去重了,如果你需要对一些数据进行快速的全局去重,你当然也可以基于 JVM 内存里的 HashSet 进行去重,但是如果你的某个系统部署在多台机器上呢?得基于 Redis 进行全局的 Set 去重。

  可以基于 Set 玩交集、并集、差集的操作,比如交集吧,我们可以把两个人的好友列表整一个交集,看看俩人的共同好友都有谁,对吧?

  反正这些场景比较多,因为对比很快,操作也简单,两个查询一个 Set 搞定。

Sorted Set

   Sorted set 是排序的 Set,去重但可以排序,写进去的时候给一个分数,自动根据分数排序。

  有序集合的使用场景与集合类似,但是Set集合不是自动有序的,而Sorted set 可以利用分数进行成员间的排序,而且是插入时就排序好的。所以当你需要一个有序且不重复的集合列表时,可以选择 Sorted set 数据结构作为选择方案。

  • 排行榜:有序集合景点使用场景。例如视频网站需要对用户上传的视频做排行榜,榜单维护可能是多方面的:按照时间、按照播放量、按照获得的点赞数等。
  • 用Sorted Sets 来做带权重的队列,比如普通的 score 为1,重要消息的 score 为2,然后工作线程可以选择按 score 的倒叙来获取工作任务,让重要的任务优先执行。

  微博热搜榜,就是后面的热度值,前面就是名称。

小结

  Redis 基础类型就五种,能说出这5种是可以的,但是,能把其他的说出来那就更棒了,再把这5种类型的具体使用场景,以及什么时候用什么类型最合适,那就完美了!

  要是你回答的不好,没说出几种数据类型,也没说什么场景,你完了,面试官对你印象肯定不好,觉得你平时就是做个简单的 set 和 get。所以看似很简单的面试题实则最容易看出你的深浅了,大家都要注意打好基础

Redis系列二 - 数据结构的更多相关文章

  1. Redis系列(二):Redis的数据类型及命令操作

    原文链接(转载请注明出处):Redis系列(二):Redis的数据类型及命令操作 Redis 中常用命令 Redis 官方的文档是英文版的,当然网上也有大量的中文翻译版,例如:Redis 命令参考.这 ...

  2. Redis系列(二):Redis的5种数据结构及其常用命令

    上一篇博客,我们讲解了什么是Redis以及在Windows和Linux环境下安装Redis的方法, 没看过的同学可以点击以下链接查看: Redis系列(一):Redis简介及环境安装. 本篇博客我们来 ...

  3. redis 系列8 数据结构之整数集合

    一.概述 整数集合(intset)是集合键的底层实现之一, 当一个集合只包含整数值元素,并且这个集合元素数量不多时, Redis就会使用整数集合作为集合键的底层实现.下面创建一个只包含5个元素的集合键 ...

  4. redis 系列5 数据结构之字典(上)

    一. 概述 字典又称符号表(symbol table),关联数组(associative array), 映射(map),是一种用于保存键值对(key-value pair)的抽象数据结构.在字典中, ...

  5. redis 系列4 数据结构之链表

    一. 概述 链表提供了高效的节点重排能力,以及顺序性的节点访问方式,并且可能通过增删节点来灵活地调整链表的长度.作为一种数据结构,在C语言中并没有内置的这种数据结构.所以Redis构建了自己的链表实现 ...

  6. Redis系列(二)-Hredis客户端设计及开源

    接上篇c#实现redis客户端(一),重新整理些了下. 阅读目录: 项目说明 Hredis设计图 单元测试场景 总结 项目说明 背景:因为有地方要用,而又没找到对sentinel良好支持的Net客户端 ...

  7. Redis系列二之事务及消息通知

    一.事务 Redis中的事务是一组命令的集合.一个事务中的命令要么都执行,要么都不执行. 1.事务简介 事务的原理是先将一个事务的命令发送给Redis,然后再让Redis依次执行这些命令.下面看一个示 ...

  8. redis 系列7 数据结构之跳跃表

    一.概述 跳跃表(skiplist)是一种有序数据结构,它通过在每个节点中维持多个指向其他节点的指针,从而达到快速访问节点的目的.在大部分情况下,跳跃表的效率可以和平衡树(关系型数据库的索引就是平衡树 ...

  9. redis 系列6 数据结构之字典(下)

    一.概述 接着上篇继续,这篇把数据结构之字典学习完, 这篇知识点包括:哈希算法,解决键冲突, rehash , 渐进式rehash,字典API. 1.1 哈希算法 当一个新的键值对 需要添加到字典里面 ...

随机推荐

  1. spring创建bean异常

    org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'requestMappi ...

  2. MyEclipse10安装properties文件插件

    安装步骤 1.下载PropertiesEditor插件 http://propedit.sourceforge.jp/index_en.html 2.解压出features.plugins文件 3.在 ...

  3. iOS仿写有妖气漫画、视频捕获框架、启动页广告页demo、多种动画效果等源码

    iOS精选源码 以tableview的section为整体添加阴影效果/ta'b'le'vi'e'w顶部悬浮.... 一个可以轻松应用自定义过滤器的视频捕获框架. 基于UITableView的组件,旨 ...

  4. 吴裕雄--天生自然python学习笔记:python的Bokeh 基本绘图

    使用 Bokeh 绘图时,其大部分绘图功能是由 bokeh plotting 完成的,所以我们一 般至少要导入自gure 及 show 这两个函数 : Bokeh 绘制的图形是在浏览器中显示的, 创建 ...

  5. 同步linux系统时间

    Linux的时间分为System Clock(系统时间)和Real Time Clock (硬件时间,简称RTC). 系统时间:指当前Linux Kernel中的时间. 硬件时间:主板上有电池供电的时 ...

  6. SHELL用法七(Sed语句)

    1.SHELL编程Sed语句案例实战 1)SHELL编程四剑客之二的Sed工具,主要是用于Linux系统文本文件的编辑. 打印的,也称为非交互模式编辑器(vi|vim交互模式编辑器),Sed工具的语法 ...

  7. jstl引入报错

    jstl1.0的引入方式为: <taglib uri="http://java.sun.com/jstl/core" prefix="c" /> j ...

  8. Typescript - 联合类型

    原文:TypeScript基本知识点整理 零.序言 联合类型表示一个变量值可以是几种类型之一,我们可以使用 “|” 来分割每个类型: 联合类型的变量在被赋值时,会根据类型推断的规则推断出一个类型: 如 ...

  9. IPFS问题总结

    1.安装包下载 ipfs安装版本下载:https://github.com/ipfs/go-ipfs/releases,这是IPFS的go语言实现版,目前实现的还有js版本. 2.安装与启动 linu ...

  10. ASP.NET MVC4网站搭建与发布【最新】

    ASP.NET MVC4网站搭建与发布 一些往事 2015年,仅仅大二的我怀着一颗创业之心,加入了常熟派英特,成为阳光职场平台的创始之一,并肩负了公司技术部的大梁,当时阳光职场正在从线下服务向互联网化 ...