美文网首页
Redis--列表

Redis--列表

作者: Audience0 | 来源:发表于2018-07-03 15:44 被阅读0次

列表(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(消息队列)

相关文章

  • Redis--列表

    列表(list)类型是用来存储多个有序的字符串,一个列表最多可以储存2^32 - 1个元素,列表是比较灵活的数据结...

  • Redis--压缩列表

    应用范围 1.是列表和哈希键的底层实现之一, 2.只要包含少量的列表项,且列表项只能是小整数值或者长度较短的字符串...

  • Redis--复制

    Redis--复制 复制功能的实现 1.通过SLAVEOF命令可以让从服务器同步主服务器的数据。 旧版复制实现的机...

  • Redis--哈希

    哈希类型是指键值本身又是一个键值对结构 -----------------------------命令 ---设置...

  • Redis--命令

    设值 获值 设置过期时间(单位:s) 设置过期时间(单位:s) 设置过期时间(单位:ms) 设置UNIX过期时间戳...

  • Redis--集合

    集合(set)类型也是用来保存多个字符串元素的,但是和列表不一样的是,集合中不允许有重复元素,并且集合中元素是无序...

  • redis--使用

    一:redis中的数据类型 redis的数据存储:key=value 键值对 key<键>的数据类型:字符串 va...

  • redis--使用

    一:redis中的数据类型 redis的数据存储:key=value 键值对 key<键>的数据类型:字符串 va...

  • Redis--字典

    字典的应用范围 1.redis的DB就是一个字典 2.redis的hash键,当包含的键值较多,又或者键值对中的元...

  • Redis--链表

    链表 链表作用范围 1.列表键包含的数量较多时候使用。 2.列表中包含的元素都是较长的字符串时候使用 链表节点的组...

网友评论

      本文标题:Redis--列表

      本文链接:https://www.haomeiwen.com/subject/cnmluftx.html