Redis--列表

列表(list)类型是用来存储多个有序的字符串,一个列表最多可以储存2^32 - 1个元素,列表是比较灵活的数据结构,它可以充当栈和队列的角色。

列表类型特点:

    1.列表中的元素是有序的,这就意味着可以通过索引下标获取某个元素或者某个范围内的元素。

    2.列表中的元素可以是重复的


命令:

插入:

-- 从右边插入

rpush key value [value ...]

-- 从左侧插入

lpush key value [value...]

-- 向某个元素前或后插入元素

linsert key before|after element value

linsert 命令会从列表中找到等于element的元素,在其前或者后插入一个新的元素value


查找:

-- 获取指定范围内的元素列表

lrange key start end 

lrange 操作会获取列表指定索引范围的所有元素。索引下标从左到右分别是0 ~ N-1, 并且 lrange的end包含本身 

-- 获取列表指定索引下标的元素

lindex key index

获取最后一个元素可以为lindex key -1

-- 获取列表长度

llen key


删除:

--从列表左侧弹出元素

lpop key 

--从列表有测弹出元素

rpop key

--删除指定元素

lrem key count value

lrem命令会从列表中找到等于value的元素进行删除,根据count的不同分为三种情况,

count  > 0 从左到右,删除最多count个元素

count < 0 从右到左,删除最多count绝对值个元素

count = 0 删除所有

-- 按照索引范围修剪列表

ltrim key start end 

ltrim操作会使列表保留start--end之间的元素,包含start  end对应的元素


修改:

-- 修改指定索引下标的元素

lset key index newValue


阻塞:

-- 阻塞式弹出

blpop key [key...] timeout

brpop key [key...] timeout

blpop和brpop是lpop和rpop的阻塞版本,

参数说明:

--key [key...] 多个列表的键

--timeout:阻塞时间(单位:秒)

    列表为空:如果timeout=3,那么客户端要等到3秒后返回,如果timeout=0,那么客户端一直阻塞等下去,但是如果在阻塞期间,其他客户端添加了数据,使列表不为空,则会立即返回

    列表不为空,客户端会立即返回

--在使用brpop时有两点需要注意

    第一点:如果多个键,那么brpop会从左至右遍历键,一旦有一个键能弹出元素,客户端变会立即返回,如果此时另一个客户端向空列表中插入数据,客户端会立即返回相应的列表弹出的元素。

    第二点:如果多个客户端对同一个键执行brpop,那么最先执行brpop命令的客户端可以获取到弹出的值


-- 内部编码:

ziplist(压缩列表):当列表的元素个数小于list-max-ziplist-entries配置(默认512个),同时列表中每个元素 的值都小于list-max-ziplist-value配置(默认64字节),Redis会选用ziplist来作为列表的内部实现,来减少内存的使用。

linkedlist(链表):当列表类型无法满足ziplist的条件时,Redis会使用linkedlist作为列表的内部实现。

quicklist:Redis 3.2提供,是以一个ziplist为节点的linkedlist,参考微博:https://matt.sh/redis-quicklist


-- 使用实例

    消息队列:

            lpush+brpop组合可实现阻塞消息队列,生产者客户端使用lpush从列表左侧插入元素,多个消费者客户端从列表右侧使用brpop命令阻塞式的抢列表尾部的元素,多个客户端保证了消费者的负载均衡和高可用性。

    --------------------------------------------------------------------------------------------------------------------------------

lpush + lpop = stack(栈)

lpush + rpop = Queue(队列)

lpush + ltrim = Capped Collection(有限集合)

lpush + brpop = Message Queue(消息队列)

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,937评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,503评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,712评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,668评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,677评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,601评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,975评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,637评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,881评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,621评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,710评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,387评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,971评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,947评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,189评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,805评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,449评论 2 342

推荐阅读更多精彩内容

  • 列表类型简介 列表(list)用于存储多个有序的字符串。列表是一种比较灵活的数据结构,可以充当栈和队列的角色,在实...
    闲睡猫阅读 5,903评论 0 3
  • 1. 概述: 在Redis中,List类型是按照插入顺序排序的~字符串链表。和数据结构中的普通链表一样,我们可以在...
    六月星空2011阅读 342评论 0 0
  • Redis 列表(List) 命令 下表列出了列表相关的基本命令: 1> blpop 命令:移出并获取列表的第一个...
    stakeing阅读 1,299评论 0 0
  • 1.Redis特性 1)速度快:数据存放在内存上、基于C语言实现、单线程架构预防多线程竞争问题;2)基于键值对的数...
    Sponge1128阅读 614评论 0 1
  • 一代梁王,初分晋地,双鱼正照夷门。卧牛城阔,相接四边村。多少金明陈迹,上林苑花发三春。绿杨外,溶溶汴水,千里接龙津...
    chi樂22阅读 673评论 0 0