当前位置: 代码网 > it编程>数据库>Redis > Redis常见数据类型List列表使用详解

Redis常见数据类型List列表使用详解

2024年12月08日 Redis 我要评论
前言在 redis 中,list是一种非常常见的数据类型,用于表示一个有序的字符串集合。与传统的链表结构类似,redis 的 list 支持在两端进行高效的插入和删除操作,因此非常适合实现队列(que

前言

在 redis 中,list 是一种非常常见的数据类型,用于表示一个有序的字符串集合。与传统的链表结构类似,redis 的 list 支持在两端进行高效的插入和删除操作,因此非常适合实现队列(queue)和栈(stack)等数据结构。

redis list 的基本概念

  • 有序的字符串集合:list中的元素按插入顺序排列,每个元素都是一个字符串。
  • 双端队列:redis list 是一个双端队列(deque),允许你在列表的两端高效地进行操作(插入和删除)。
  • 最大长度:redis 的 list 数据类型没有最大长度限制,理论上可以存储无限多的元素,除非内存不足。

list命令:

lpush

lpush 命令用于将一个或多个元素插入到列表的头部(即左侧)。如果列表不存在,redis 会自动创建一个空列表并执行插入操作。

语法: lpush key value [value ...] 

127.0.0.1:6379> lpush key 1 2 3 4
(integer) 4
127.0.0.1:6379> lrange key 0 -1
1) "4"
2) "3"
3) "2"
4) "1"

返回值

  • 返回插入元素后的列表长度。

lpushx 

lpushx 是一个用于将元素推入到列表(list)头部的命令,但与 lpush 不同的是,lpushx 只有在列表已存在的情况下才会执行操作。如果列表不存在,lpushx 不会做任何操作,也不会创建新的列表。 

语法:lpushx key value

127.0.0.1:6379> lpush key world
(integer) 1
127.0.0.1:6379> lpushx key hello 
(integer) 2
127.0.0.1:6379> lpushx key2 hi 
(integer) 0
127.0.0.1:6379> lrange key 0 -1
1) "hello"
2) "world"
127.0.0.1:6379> lrange key2 0 -1
(empty array)

总结:

lpushx 用于将元素添加到已经存在的列表中,它不会创建新的列表,这与 lpush(无论列表是否存在都创建新列表)有所不同。

 rpush

rpush 命令用于将一个或多个元素插入到列表的尾部(即右侧)。如果列表不存在,redis 会自动创建一个空列表并执行插入操作。

语法:rpush key value [value ...] 

127.0.0.1:6379> rpush key 1 2 3 4
(integer) 4
127.0.0.1:6379> rpush key 5 6 7 8
(integer) 8
127.0.0.1:6379> lrange key 0 -1
1) "1"
2) "2"
3) "3"
4) "4"
5) "5"
6) "6"
7) "7"
8) "8"

返回值:

  • 返回插入元素后的列表长度。

rpushx 同理 lpushx

lrange

lrange 命令用于获取列表中的一个指定范围的元素。你可以指定开始和结束的索引位置,然后 redis 会返回该范围内的所有元素。

语法:lrange key start stop

127.0.0.1:6379> lrange key 0 -1
1) "1"
2) "2"
3) "3"
4) "4"
5) "5"
6) "6"
7) "7"
8) "8"
127.0.0.1:6379> lrange key 0 3
1) "1"
2) "2"
3) "3"
4) "4"
127.0.0.1:6379> lrange key 0 100
1) "1"
2) "2"
3) "3"
4) "4"
5) "5"
6) "6"
7) "7"
8) "8"
127.0.0.1:6379> lrange key 8 10
(empty array)
127.0.0.1:6379> lrange key -8 -1
1) "1"
2) "2"
3) "3"
4) "4"
5) "5"
6) "6"
7) "7"
8) "8"

返回值:

  • 返回指定范围内的所有元素。如果范围超出列表长度,redis 会返回所有符合范围条件的元素。

总结:

  • lrange 用于获取 redis 列表中指定范围的元素。
  • 支持负数索引,可以从列表尾部获取元素。
  • 如果 start 和 stop 超出了列表的实际长度,redis 会自动调整范围。

lpop

lpop 命令用于从列表的头部(左侧)移除并返回一个元素。执行该命令时,列表的第一个元素会被移除,并返回这个被移除的元素。如果列表为空,lpop 会返回 nil

语法:lpop key

127.0.0.1:6379> rpush key 1 2 3 4
(integer) 4
127.0.0.1:6379> lpop key
"1"
127.0.0.1:6379> lpop key
"2"
127.0.0.1:6379> lpop key
"3"
127.0.0.1:6379> lpop key
"4"
127.0.0.1:6379> lpop key
(nil)

返回值:

  • 返回被移除的列表元素。
  • 如果列表为空,返回 nil

总结:

lpop 是一个用于从 redis 列表左侧移除并返回一个元素的命令。如果列表为空,返回 nil

rpop 同理 
 rpop 命令用于从列表的尾部(右侧)移除并返回一个元素。执行该命令时,列表的最后一个元素会被移除,并返回该元素。如果列表为空,rpop 会返回 nil

lindex

lindex 命令用于获取列表中指定位置的元素。你可以通过指定一个索引来获取列表中对应位置的元素。

语法:lindex key index

127.0.0.1:6379> rpush key 1 2 3 4 5 6 7 8
(integer) 8
127.0.0.1:6379> lindex key 0
"1"
127.0.0.1:6379> lindex key 7
"8"
127.0.0.1:6379> lindex -1
127.0.0.1:6379> lindex key -1
"8"
127.0.0.1:6379> lindex key -7
"2"
127.0.0.1:6379> lindex key 9
(nil)

返回值:

        返回指定位置的元素。

        如果指定的索引超出了列表的范围,返回 nil

总结:

lindex 用于获取 redis 列表中指定位置的元素。可以通过正数索引或负数索引来指定位置。如果索引超出范围,返回 nil。这是一个读取操作,而不会改变列表内容

linsert

linsert 命令用于在列表中指定位置插入一个元素。你可以在列表的 左侧 或 右侧 插入元素,依据你指定的插入位置。语法:linsert key before|after pivot element 

127.0.0.1:6379> rpush key a b c d
(integer) 4
127.0.0.1:6379> linsert key before b 111
(integer) 5
127.0.0.1:6379> linsert key after b 222
(integer) 6
27.0.0.1:6379> linsert key before e 333
(integer) -1
127.0.0.1:6379> lrange key 0 -1
1) "a"
2) "111"
3) "b"
4) "222"
5) "c"
6) "d"

返回值:

        如果操作成功,返回列表的新长度。

        如果 pivot 元素在列表中不存在,则不插入任何元素,返回 -1

总结:

linsert 命令在 redis 列表中指定位置插入一个新元素。可以在指定元素的 前 或 后 插入。它是一个修改列表的命令,成功执行后返回新的列表长度,如果指定的 pivot 元素不存在,则返回 -1

 llen

llen 命令用于获取列表的长度,即列表中元素的数量。

语法:llen key 

127.0.0.1:6379> lrange key 0 -1
1) "a"
2) "111"
3) "b"
4) "222"
5) "c"
6) "d"
127.0.0.1:6379> llen key
(integer) 6
127.0.0.1:6379> llen key2
(integer) 0

返回值:

返回列表中元素的数量。如果该 key 对应的不是一个列表,或者该列表为空,返回 0

如果 key 不存在,返回 0

总结:

llen 命令用于获取 redis 列表的长度,返回列表中元素的数量。如果列表为空或不存在,返回 0

 阻塞版本命令

 blpop 和 brpop 是 lpop 和 rpop 的阻塞版本,和对应非阻塞版本的作用基本⼀致,除了: 
• 在列表中有元素的情况下,阻塞和⾮阻塞表现是⼀致的。但如果列表中没有元素,非阻塞版本会理解返回 nil,但阻塞版本会根据 timeout,阻塞⼀段时间,期间 redis 可以执行其他命令,但要求执行该命令的客户端会表现为阻塞状态(如图 2-22 )。 
• 命令中如果设置了多个键,那么会从左向右进⾏遍历键,⼀旦有一个键对应的列表中可以弹出元素,命令立即返回。
• 如果多个客户端同时多⼀个键执行 pop,则最先执行命令的客户端会得到弹出的元素。 

图 2-22 阻塞版本的 blpop 和 非阻塞版本 lpop 的区别

演示一下blpop

blpop 命令是 阻塞式弹出(blocking pop)命令,它用于从一个或多个列表中弹出一个元素。如果列表为空,命令会阻塞,直到有元素可弹出为止,或者超时。

语法:blpop key [key ...] timeout

此时再开一个服务器去增加key里面的元素

此时发现它在100内只有接收到key中是否有信息即可

返回值:

        如果成功弹出了元素,返回一个列表,包含两个元素:

        第一个元素是列表名称 key

        第二个元素是从该列表中弹出的值。

        如果在 timeout 时间内没有元素可弹出,命令返回 nil

总结:

blpop 是 redis 中的阻塞式弹出命令,可以从一个或多个列表中弹出元素。它会阻塞直到列表中有元素可供弹出,或者超时。如果超时,命令返回 nil。此命令常用于任务队列或消息队列的实现。

 brpop同理blpop

list使用场景

消息队列

redis 可以使用 lpush + brpop 命令组合实现经典的阻塞式生产者-消费者模型队列,
生产者客户端使用 lpush 从列表左侧插入元素,多个消费者客户端使用 brpop 命令阻塞式地从队列中 "争抢" 队首元素。通过多个客户端来保证消费的负载均衡和高可用性。 

总结 

到此这篇关于redis常见数据类型list列表使用详解的文章就介绍到这了,更多相关redis list列表详解内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

  • 使用Redis实现数据库对象自增ID的方法

    使用Redis实现数据库对象自增ID的方法

    在分布式项目中,数据表的主键id一般可能存在于uuid或自增id这两种形式,uuid好理解而且实现起来也最容易,但是缺点就是数据表中的主键id是32位的字符串,... [阅读全文]
  • Redis存储断点续传文件状态的最佳实践

    Redis存储断点续传文件状态的最佳实践

    1.redis中存储文件上传状态redis 提供了丰富的数据结构,可以灵活地存储和更新文件上传的各类状态。以下是几种常见的实现方式。使用 hash 存储文件状态... [阅读全文]
  • Redis GEO实现附近搜索功能

    Redis GEO实现附近搜索功能

    公司最近来了一个新项目,做小程序招聘。其中有一个需求是实现附近岗位推荐。由于用户量不大,决定采用redis来实现。之前没有接触过。现在用来记录一下。(redis... [阅读全文]
  • Redis连接池配置方式

    Redis连接池配置方式

    连接池配置一、redis连接池与jdbc中在与数据库进行连接时耗时,从而需要引入连接池一样。java在与redis进行连接也是需要时间的。所以在java于red... [阅读全文]
  • Redis集群的实现全过程

    Redis集群的实现全过程

    redis 作为一款高性能的内存数据库,被广泛应用于各种场景。然而,随着数据量的不断增长和业务需求的日益复杂,单节点的 redis 往往无法满足需求,这时就需要... [阅读全文]
  • Redis分片集群的实现示例

    Redis分片集群的实现示例

    前序:redis集群搭建直接一步到位:支持海量数据以及高并发写分片集群顾名思义,将数据分开存储到redis集群中,这样能够存储更多的数据,避免浪费资源,基础搭建... [阅读全文]

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com