Redis的列表类型是简单的字符串列表,按照插入顺序排序,你可以从列表的头部或者尾部添加元素,也支持按照索引范围获取元素,是Redis中实用性很高的数据结构之一。

Redis列表类型基础特性
Redis列表本质上是一个双向链表结构,这意味着它从头部和尾部插入、删除元素的效率都很高,时间复杂度为O(1),但如果要通过索引访问中间元素,时间复杂度会变为O(n)。列表最多可以存储2^32 - 1个元素,足够满足绝大多数业务场景的需求。
列表类型常用操作命令
元素添加命令
向列表添加元素最常用的两个命令是LPUSH和RPUSH,分别是从列表头部和尾部插入元素,下面是操作示例:
# 从列表头部插入元素,返回插入后列表的长度 LPUSH mylist "hello" LPUSH mylist "world" # 从列表尾部插入元素 RPUSH mylist "redis" # 此时mylist的元素顺序为 world, hello, redis
元素查询命令
查询列表元素常用LRANGE命令,它支持按照索引范围返回元素,索引从0开始,负数代表从尾部开始计数:
# 获取列表所有元素 LRANGE mylist 0 -1 # 返回结果:1) "world" 2) "hello" 3) "redis" # 获取前两个元素 LRANGE mylist 0 1 # 返回结果:1) "world" 2) "hello"
元素弹出命令
如果需要从列表中取出并删除元素,可以使用LPOP和RPOP命令,分别对应从头部和尾部弹出元素:
# 从列表头部弹出元素 LPOP mylist # 返回结果:"world",此时mylist剩余元素为 hello, redis # 从列表尾部弹出元素 RPOP mylist # 返回结果:"redis",此时mylist剩余元素为 hello
列表类型的典型使用场景
简易消息队列
利用列表的LPUSH和RPOP命令可以实现简易的消息队列功能,生产者往列表头部投递消息,消费者从列表尾部取出消息进行处理:
# 生产者投递消息 LPUSH msg_queue "task1" LPUSH msg_queue "task2" # 消费者取出消息,没有消息时会返回nil RPOP msg_queue # 返回结果:"task1"
如果需要实现阻塞式取消息,避免无用轮询,可以使用BRPOP命令,它会在列表没有元素时阻塞连接,直到有新元素加入或者超时:
# 阻塞10秒取消息,10秒内没有新消息则返回nil BRPOP msg_queue 10
最新数据展示
比如需要展示网站最新的10条用户评论,就可以使用列表存储评论内容,每次新增评论时从头部插入,然后通过LRANGE获取前10条即可:
# 新增评论 LPUSH comments "用户A:这篇文章很有用" LPUSH comments "用户B:讲解很清晰" # 获取最新10条评论 LRANGE comments 0 9
分页查询
对于不需要复杂排序的列表类数据,可以利用LRANGE的索引特性实现分页,比如每页展示10条数据,第n页的查询范围就是 (n-1)*10 到 n*10 -1:
# 查询第2页数据,每页10条 LRANGE article_list 10 19
使用注意事项
- 列表索引访问中间元素效率较低,如果频繁需要按索引访问,建议考虑其他数据结构
- 使用阻塞命令时需要注意连接超时的问题,避免长时间阻塞占用连接资源
- 列表元素数量较大时,执行
LRANGE获取大范围元素可能会阻塞Redis服务,建议控制单次获取的元素数量