Redis的各种数据类型实践---List结构

时间:2022-07-25
本文章向大家介绍Redis的各种数据类型实践---List结构,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

Redis 列表(list)

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

一个列表最多可以包含2的32次方减1 个元素 (4294967295, 每个列表超过40亿个元素)。

常用命令

LPUSH key value [value ...] //将一个或多个值value插入到key列表的表头(最左边)
RPUSH key value [value ...]//将一个或多个值value插入到key列表的表尾(最右边)
LPOP key//移除并返回key列表的头元素
RPOP key//移除并返回key列表的尾元素
LRANGE key start stop//返回列表key中指定区间内的元素,区间以偏移量start和stop指定

BLPOP key [key ...] timeout//从key列表表头弹出一个元素,若列表中没有元素,阻塞等待timeout秒,如果timeout=0,一直阻塞等待
BRPOP key [key ...] timeout //从key列表表尾弹出一个元素,若列表中没有元素,阻塞等待timeout秒,如果timeout=0,一直阻塞等待
LLEN key //list的长度

应用场景

1、实现常见的数据结构

基于List的特性及丰富的命令可以实现常用的集中数据结构

1)Stack (栈) LPUSH +LPOP ,FILO 先入后出 结合LPUSH和LPOP命令实现栈的先进后出的特性,LPUSH从左边入栈,LPOP从左边出栈,先进入的后出来。相当于入口出口是一个。

2)Queue (队列)= LPUSH +RPOP ,FIFO 先进先出

结合LPUSH和RPOP命令实现队列的先进先出的特性,LPUSH从左边入队,RPOP从右边出队,先进来的先出来。相当于入口出口各在两边。

3)Blocking MQ 阻塞队列 = LPUSH+BRPOP

结合LPUSH和BRPOP实现阻塞队列,BRPOP比RPOP多了一个timeout的参数,是一个等待的最大时间,如果在这个时间内拿不到数据则返回空。

2、微博消息公众号消息 例如:个人微博账户关注了人民网、华为等大V,现在华为发了一条微博 ID为3306,我关注了他,那么就会往我的msg队列push 这个微博ID。当我打开微博时,就会从我的专属队列里去前几个微博ID展示给我。 1)华为发了微博,ID 3306 消息入队

LPUSH  msg:{个人-ID}  3306

2)人民网发了个ID为3308的消息,消息入队

LPUSH  msg:{个人-ID}  3308

3)我登陆进去展示最新消息,就从个人专属消息队列取最新的5条显示

LRANGE    msg:{个人-ID}  0 5