列表
列表(list)类型是用来存储多个有序的字符串,在Redis中,可以对列表两端插入(push)和弹出(pop),还可以获取指定范围的元素列表、获取指定索引下标的元素等,列表是一种比较灵活的数据结构,它可以充当栈和队列的角色。
列表元素是有序的,元素是可以重复的。
命令
添加
#从右边插入元素
rpush key value [value ...]
#从左边插入元素
lpush key value [value ...]
#向某个元素前或者后插入元素
linsert key before|after pivot value
#查询列表所有值
lrange key 0 -1
查找
#获取指定范围内的元素列表
#索引下标有两个特点:
#第一:索引下标从左到右分别0到N-1,从右到左分别是-1到-N
#第二:lrange中的end选项包含了自身
lrange key start end
#获取列表指定下标
lindex key index
#获取列表长度
llen key
删除
#从列表左侧弹出元素
lpop key
#从列表右侧弹出
rpop key
#删除指定元素
#lrem命令会从列表中找到等于value的元素进行删除
#count>0,从左到右,删除最多count个元素。
#count<0,从右到左,删除最多count绝对值个元素。
#count=0,删除所有
lrem key count value
#按照索引范围修剪列表
#例如:ltrim listkey 1 3 ,保留listkey第2个到第4个元素
ltrim key start end
修改
#修改指定索引下标的元素
lset key index newValue
堵塞操作
#key[key...]:多个列表的键
#timeout:阻塞时间(单位:秒)
blpop key [key ...] timeout
brpop key [key ...] timeout
内部编码
ziplist:value小于64个字节,并且field个数不会超过512个
hashtable:当列表类型无法满足ziplist的条件时,Redis会使用 linkedlist作为列表的内部实现
注意:Redis3.2版本提供了quicklist内部编码,简单地说它是以一个ziplist为节 点的linkedlist,它结合了ziplist和linkedlist两者的优势,为列表类型提供了一 种更为优秀的内部编码实现
使用场景
消息队列
Redis的lpush(生产者客户端)+brpop(消费者客户端)命令组合即可实现阻塞队列
文章列表
列表不但是有序的,同时支持按照索引范围获取元素。
小结:
·lpush+lpop=Stack(栈)
·lpush+rpop=Queue(队列)
·lpsh+ltrim=Capped Collection(有限集合)
·lpush+brpop=Message Queue(消息队列