Redis六大数据类型使用方法详解

  我们说 redis 相对于memcache 等其他的缓存产品,有一个比较明显的优势就是 redis 不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。本篇博客我们就将介绍这些数据类型的详细使用以及顺带介绍redis系统的相关命令用法。

  注意:redis的命令不区分大小写,但是key 严格区分大小写!!!

0、写在前面

  下面介绍的redis命令有很多,如果你想通过死记硬背来记住这些命令几乎不可能,但是如果理解了redis的一些机制,这些命令其实是由很强的通用性的,通过理解来记忆是最好的。 另外,每种数据类型都有其适合的使用场景,我也会在文中给与说明,如果滥用,反而会适得其反。

1、string 数据类型

  string 是redis的最基本的数据类型,可以理解为与 memcached 一模一样的类型,一个key 对应一个 value。string 类型是二进制安全的,意思是 redis 的 string 可以包含任何数据,比如图片或者序列化的对象,一个 redis 中字符串 value 最多可以是 512m。

①、相关命令介绍

  string 数据类型在 redis 中的相关命令:

  

  ps:

  ①、上面的 ttl 命令是返回 key 的剩余过期时间,单位为秒。

  ②、mset和mget这种批量处理命令,能够极大的提高操作效率。因为一次命令执行所需要的时间=1次网络传输时间+1次命令执行时间,n个命令耗时=n次网络传输时间+n次命令执行时间,而批量处理命令会将n次网络时间缩减为1次网络时间,也就是1次网络传输时间+n次命令处理时间。

  但是需要注意的是,redis是单线程的,如果一次批量处理命令过多,会造成redis阻塞或网络拥塞(传输数据量大)。

  ③、setnx可以用于实现分布式锁,具体实现方式后面会介绍。

  上面是 string 类型的基本命令,下面介绍几个自增自减操作,这在实际工作中还是特别有用的(分布式环境中统计系统的在线人数,利用redis的高性能读写,在redis中完成秒杀,而不是直接操作数据库。)。

  

②、典型使用场景

  一、计数

  由于redis单线程的特点,我们不用考虑并发造成计数不准的问题,通过 incrby 命令,我们可以正确的得到我们想要的结果。

  二、限制次数

  比如登录次数校验,错误超过三次5分钟内就不让登录了,每次登录设置key自增一次,并设置该key的过期时间为5分钟后,每次登录检查一下该key的值来进行限制登录。

2、hash 数据类型

  hash 是一个键值对集合,是一个 string 类型的 key和 value 的映射表,key 还是key,但是value是一个键值对(key-value)。类比于 java里面的 map<string,map<string,object>> 集合。

①、相关命令介绍

  演示如下:

②、典型使用场景

  查询的时间复杂度是o(1),用于缓存一些信息。

3、list 数据类型

  list 列表,它是简单的字符串列表,按照插入顺序排序,你可以添加一个元素到列表的头部(左边)或者尾部(右边),它的底层实际上是个链表。

  列表有两个特点:

  一、有序

  二、可以重复

  这两个特点要注意和后面介绍的集合和有序集合相对比。

①、相关命令介绍

  

  

②、典型使用场景

  一、栈

  通过命令 lpush+lpop

  二、队列

  命令 lpush+rpop

  三、有限集合

  命令 lpush+ltrim

  四、消息队列

  命令 lpush+brpop

4、set 数据类型

  redis 的 set 是 string 类型的无序集合。

  相对于列表,集合也有两个特点:

  一、无序

  二、不可重复

①、相关命令介绍

  

②、典型使用场景

  利用集合的交并集特性,比如在社交领域,我们可以很方便的求出多个用户的共同好友,共同感兴趣的领域等。

5、zset 数据类型

  zset(sorted set 有序集合),和上面的set 数据类型一样,也是 string 类型元素的集合,但是它是有序的。

①、相关命令介绍

  

②、典型使用场景

  和set数据结构一样,zset也可以用于社交领域的相关业务,并且还可以利用zset 的有序特性,还可以做类似排行榜的业务。

6、redis5.0新数据结构-stream

  redis的作者在redis5.0中,放出一个新的数据结构,stream。redis stream 的内部,其实也是一个队列,每一个不同的key,对应的是不同的队列,每个队列的元素,也就是消息,都有一个msgid,并且需要保证msgid是严格递增的。在stream当中,消息是默认持久化的,即便是redis重启,也能够读取到消息。那么,stream是如何做到多播的呢?其实非常的简单,与其他队列系统相似,redis对不同的消费者,也有消费者group这样的概念,不同的消费组,可以消费同一个消息,对于不同的消费组,都维护一个idx下标,表示这一个消费群组消费到了哪里,每次进行消费,都会更新一下这个下标,往后面一位进行偏移。

7、系统相关命令

8、key 相关命令

  关于 key 的命令应该说是最常用的,需要大家记住。

  

  这里在介绍一个命令 :

object encoding key

  这是用来显示这五种数据类型的底层数据结构,下一篇博客我们会详细介绍。

  

  上面的命令我们给string 数据类型 k1 复制str,给 k2 复制123,通过 object encoding 显示底层实现的数据类型分别是 embstr 和 int。

参考文档:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持www.887551.com。

(0)
上一篇 2022年3月21日
下一篇 2022年3月21日

相关推荐