Redis学习笔记-List列表(2)

先赞后看,养成习惯!!! ^ _ ^ ❤️ ❤️ ❤️
码字不易,大家的支持就是我坚持下去的动力,点赞后不要忘记关注我哦

个人主页:伯明翰java

文章专栏:redis

如有错误,请您指正批评 ^ _ ^

List内部编码

列表类型的内部编码有两种:

  • ziplist(压缩列表):当列表的元素个数⼩于list-max-ziplist-entries 配置(默认512个),同时列表中每个元素的⻓度都⼩于list-max-ziplist-value配置(默认64字节)时,Redis会选⽤ziplist来作为列表的内部编码实现来减少内存消耗。
  • linkedlist(链表):当列表类型⽆法满⾜ziplist的条件时,Redis会使⽤linkedlist作为列表的内部实现。
  1. 当元素个数较少且没有⼤元素时,内部编码为ziplist
powershell 复制代码
127.0.0.1:6379> rpush listkey e1 e2 e3
OK
127.0.0.1:6379> object encoding listkey
"ziplist"
  1. 当元素个数超过512时,内部编码为linkedlist
powershell 复制代码
127.0.0.1:6379> rpush listkey e1 e2 e3 ... 省略 e512 e513
OK
127.0.0.1:6379> object encoding listkey
"linkedlist"
  1. 当某个元素的⻓度超过64字节时,内部编码为linkedlist
powershell 复制代码
127.0.0.1:6379> rpush listkey "one string is bigger than 64 bytes ... 省略 ..."
OK
127.0.0.1:6379> object encoding listkey
"linkedlist"

使⽤场景

消息队列

如图2-1所⽰,Redis可以使⽤lpush+brpop 命令组合实现经典的阻塞式⽣产者-消费者模型队列,⽣产者客⼾端使⽤lpush从列表左侧插⼊元素,多个消费者客⼾端使⽤brpop命令阻塞式地从队列中"争抢"队⾸元素。通过多个客⼾端来保证消费的负载均衡和⾼可⽤性。
图2-1

分频道的消息队列

如图2-2所⽰,Redis同样使⽤lpush+brpop 命令,但通过不同的键模拟频道的概念,不同的消费者可以通过brpop不同的键值,实现订阅不同频道的理念。
图2-2

微博Timeline

每个⽤⼾都有属于⾃⼰的Timeline(微博列表),现需要分⻚展⽰⽂章列表。此时可以考虑使⽤列表,因为列表不但是有序的,同时⽀持按照索引范围获取元素。

  1. 每篇微博使⽤哈希结构存储,例如微博中3个属性:title、timestamp、content:
powershell 复制代码
hmset mblog:1 title xx timestamp 1476536196 content xxxxx
...
hmset mblog:n title xx timestamp 1476536196 content xxxxx
  1. 向⽤⼾Timeline添加微博,user::mblogs作为微博的键:
powershell 复制代码
lpush user:1:mblogs mblog:1 mblog:3
...
lpush user:k:mblogs mblog:9
  1. 分⻚获取⽤⼾的Timeline,例如获取⽤⼾1的前10篇微博:
powershell 复制代码
keylist = lrange user:1:mblogs 0 9
for key in keylist {
 hgetall key
}
相关推荐
石像鬼₧魂石5 小时前
如何配置Fail2Ban的Jail?
linux·学习·ubuntu
hetao17338376 小时前
2025-12-12~14 hetao1733837的刷题笔记
数据结构·c++·笔记·算法
忍冬行者6 小时前
清理三主三从redis集群的过期key和键值超过10M的key
数据库·redis·缓存
TimberWill6 小时前
使用Redis队列优化内存队列
数据库·redis·缓存
Nan_Shu_6148 小时前
学习:VueUse (1)
学习
Li.CQ8 小时前
SQL学习笔记(二)
笔记·sql·学习
Huangxy__8 小时前
指针的补充学习
学习
Smartdaili China9 小时前
掌握Java网页抓取:技术与示例完整指南
java·网络·学习·指南·网页·住宅ip·爬虫api
川石课堂软件测试9 小时前
Mysql中触发器使用详详详详详解~
数据库·redis·功能测试·mysql·oracle·单元测试·自动化