【Redis】List列表命令、编码方式及应用场景

List 列表

命令

编码方式

以前Redis对List有两种编码方式,一种是ziplist压缩列表,另一种是linkedlist链表,使用逻辑和哈希的ziplist和hashtable是一样的:具体参考((20260413212245-096hkh2 '哈希类型'))

Redis 5后,采用了quicklist的操作,相当于将ziplist的压缩特性和linkedlist的链表连接特性结合起来

应用场景

  • Redis 通常用list作为"数组"这样的结构,来存储多个元素,如
  • 作为消息队列,经典的模型就是生产者-消费者模型。消费者brpop,达到轮询的效果

    谁先执行到brpop命令,就谁先拿到这个请求,接下来又轮到消费者2、3。然后接着就是1、2、3...

brpop是block right pop,阻塞弹出,当列表为空时,就阻塞(相当于消费者在准备去"抢"这个新元素)。一直等到列表有新元素就push该元素,同时返回元素的内容。

  • 另外还有分频道的消息队列,所谓分频道就是在 Redis中有多个列表

    这种多频道,就可以在某种数据发生问题的时候也不会影响到其他数据(低耦合)

    同时消费者也可以读取多个频道(读取多个key)

PineLine

叫做流水线或者叫管道

假设列表里有很多元素,你需要循环这个列表,每一次都去取列表里的键值对元素的话,就要执行o(N)次的hgetall key,也就是很多次的网络请求。如果请求非常多,那就会导致阻塞

pineline的作用就是将多次的命令合并成一次的网络请求再进行通信。

注意,选择列表类型时,请参考:

同侧存取:(lpush + lpop)/ (rpush + rpop)为栈

异侧存取:(lpush + lrpop)/ (rpush + lpop)为队列

相关推荐
用户31693538118319 小时前
Java连接Redis
redis
倔强的石头_21 小时前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
冬奇Lab1 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence2 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
无响应de神2 天前
三、用户与权限管理
数据库·mysql
小小工匠3 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
麦聪聊数据3 天前
数据服务化时代:企业数据能力输出的核心路径
数据库
shushangyun_3 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
DARLING Zero two♡3 天前
【MySQL数据库】数据类型与表约束
数据库·mysql
曹牧3 天前
Oracle EXPLAIN PLAN
数据库·oracle