1.BLPOP key [key ...] timeout
BLPOP 是列表的阻塞式(blocking)弹出原语。
它是 LPOP 命令的阻塞版本,当给定列表内没有任何元素可供弹出的时候,连接将被 BLPOP 命令阻塞,直到等待超时或发现可弹出元素为止。
当给定多个 key 参数时,按参数 key
非阻塞行为
当 BLPOP 被调用时,如果给定 key
当存在多个给定 key 时, BLPOP 按给定 key
假设现在有 job 、 command 和 request 三个列表,其中 job 不存在, command 和 request
BLPOP job command request 0
BLPOP 保证返回的元素来自 command ,因为它是按”查找 job -> 查找 command -> 查找 request
阻塞行为
如果所有给定 key 都不存在或包含空列表,那么 BLPOP 命令将阻塞连接,直到等待超时,或有另一个客户端对给定 key
超时参数 timeout 接受一个以秒为单位的数字作为值。超时参数设为 0
相同的key被多个客户端同时阻塞
相同的 key
不同的客户端被放进一个队列中,按『先阻塞先服务』(first-BLPOP,first-served)的顺序为 key
2.BRPOP key [key ...] timeout
BRPOP 是列表的阻塞式(blocking)弹出原语。
它是 RPOP 命令的阻塞版本,当给定列表内没有任何元素可供弹出的时候,连接将被 BRPOP 命令阻塞,直到等待超时或发现可弹出元素为止。
当给定多个 key 参数时,按参数 key
关于阻塞操作的更多信息,请查看 BLPOP 命令, BRPOP 除了弹出元素的位置和 BLPOP 不同之外,其他表现一致。
可用版本:
>= 2.0.0
时间复杂度:
O(1)
返回值:
假如在指定时间内没有任何元素被弹出,则返回一个 nil
反之,返回一个含有两个元素的列表,第一个元素是被弹出元素所属的 key
3.LINDEX key index
返回列表 key 中,下标为 index
下标(index)参数 start 和 stop 都以 0 为底,也就是说,以 0 表示列表的第一个元素,以 1
你也可以使用负数下标,以 -1 表示列表的最后一个元素, -2
如果 key
可用版本:
>= 1.0.0
时间复杂度:
O(N), N 为到达下标 index
因此,对列表的头元素和尾元素执行 LINDEX 命令,复杂度为O(1)。
返回值:
列表中下标为 index
如果 index 参数的值不在列表的区间范围内(out of range),返回 nil
4.LINSERT key BEFORE|AFTER pivot value
将值 value 插入到列表 key 当中,位于值 pivot
当 pivot 不存在于列表 key
当 key 不存在时, key
如果 key
可用版本:
>= 2.2.0
时间复杂度:
O(N), N 为寻找 pivot
返回值:
如果命令执行成功,返回插入操作完成之后,列表的长度。
如果没有找到 pivot ,返回 -1
如果 key 不存在或为空列表,返回 0
5.LLEN key
返回列表 key
如果 key 不存在,则 key 被解释为一个空列表,返回 0
如果 key
可用版本:
>= 1.0.0
时间复杂度:
O(1)
返回值:
列表 key
6.LPOP key
移除并返回列表 key
可用版本:
>= 1.0.0
时间复杂度:
O(1)
返回值:
列表的头元素。
当 key 不存在时,返回 nil
7.LPUSH key value [value ...]
将一个或多个值 value 插入到列表 key
如果有多个 value 值,那么各个 value 值按从左到右的顺序依次插入到表头: 比如说,对空列表 mylist 执行命令 LPUSH mylist a bc ,列表的值将是 c b a ,这等同于原子性地执行 LPUSH mylist a 、 LPUSH mylist b 和 LPUSH mylist c
如果 key
当 key
在Redis 2.4版本以前的 LPUSH 命令,都只接受单个 value
可用版本:
>= 1.0.0
时间复杂度:
O(1)
返回值:
执行 LPUSH 命令后,列表的长度。
8.LPUSHX key value
将值 value 插入到列表 key 的表头,当且仅当 key
和 LPUSH 命令相反,当 key
可用版本:
>= 2.2.0
时间复杂度:
O(1)
返回值:
LPUSHX 命令执行之后,表的长度。
9.LRANGE key start stop
返回列表 key 中指定区间内的元素,区间以偏移量 start 和 stop
下标(index)参数 start 和 stop 都以 0 为底,也就是说,以 0 表示列表的第一个元素,以 1
你也可以使用负数下标,以 -1 表示列表的最后一个元素, -2
注意LRANGE命令和编程语言区间函数的区别
假如你有一个包含一百个元素的列表,对该列表执行 LRANGE list 0 10 ,结果是一个包含11个元素的列表,这表明 stop 下标也在 LRANGE 命令的取值范围之内(闭区间),这和某些语言的区间函数可能不一致,比如Ruby的 Range.new 、 Array#slice 和Python的 range()
超出范围的下标
超出范围的下标值不会引起错误。
如果 start 下标比列表的最大下标 end ( LLEN list 减去 1
如果 stop 下标比 end 下标还要大,Redis将 stop 的值设置为 end
可用版本:
>= 1.0.0
时间复杂度:
O(S+N), S 为偏移量 start , N
返回值:
一个列表,包含指定区间内的元素。
10.LREM key count value
根据参数 count 的值,移除列表中与参数 value
count
- count > 0 : 从表头开始向表尾搜索,移除与 value 相等的元素,数量为 count
- count < 0 : 从表尾开始向表头搜索,移除与 value 相等的元素,数量为 count
- count = 0 : 移除表中所有与 value
可用版本:
>= 1.0.0
时间复杂度:
O(N), N
返回值:
被移除元素的数量。
因为不存在的 key 被视作空表(empty list),所以当 key 不存在时, LREM 命令总是返回 0
11.LSET key index value
将列表 key 下标为 index 的元素的值设置为 value
当 index 参数超出范围,或对一个空列表( key
关于列表下标的更多信息,请参考 LINDEX 命令。
可用版本:
>= 1.0.0
时间复杂度:
对头元素或尾元素进行 LSET 操作,复杂度为 O(1)。
其他情况下,为 O(N), N
返回值:
操作成功返回 ok
12.LTRIM key start stop
对一个列表进行修剪(trim),就是说,让列表只保留指定区间内的元素,不在指定区间之内的元素都将被删除。
举个例子,执行命令 LTRIM list 0 2 ,表示只保留列表 list
下标(index)参数 start 和 stop 都以 0 为底,也就是说,以 0 表示列表的第一个元素,以 1
你也可以使用负数下标,以 -1 表示列表的最后一个元素, -2
当 key
LTRIM 命令通常和 LPUSH 命令或 RPUSH 命令配合使用,举个例子:
这个例子模拟了一个日志程序,每次将最新日志 newest_log 放到 log 列表中,并且只保留最新的 100 项。注意当这样使用 LTRIM
注意LTRIM命令和编程语言区间函数的区别
假如你有一个包含一百个元素的列表 list ,对该列表执行 LTRIM list 0 10 ,结果是一个包含11个元素的列表,这表明 stop 下标也在 LTRIM 命令的取值范围之内(闭区间),这和某些语言的区间函数可能不一致,比如Ruby的 Range.new 、 Array#slice 和Python的 range()
超出范围的下标
超出范围的下标值不会引起错误。
如果 start 下标比列表的最大下标 end ( LLEN list 减去 1 )还要大,或者 start > stop
如果 stop 下标比 end 下标还要大,Redis将 stop 的值设置为 end
可用版本:
>= 1.0.0
时间复杂度:
O(N), N
返回值:
命令执行成功时,返回 ok
13.RPOP key
移除并返回列表 key
可用版本:
>= 1.0.0
时间复杂度:
O(1)
返回值:
列表的尾元素。
当 key 不存在时,返回 nil
14.RPUSH key value [value ...]
将一个或多个值 value 插入到列表 key
如果有多个 value 值,那么各个 value 值按从左到右的顺序依次插入到表尾:比如对一个空列表 mylist 执行 RPUSH mylist a b c ,得出的结果列表为 a b c ,等同于执行命令 RPUSH mylist a 、 RPUSH mylist b 、 RPUSH mylist c
如果 key
当 key
在 Redis 2.4 版本以前的 RPUSH 命令,都只接受单个 value
可用版本:
>= 1.0.0
时间复杂度:
O(1)
返回值:
执行 RPUSH 操作后,表的长度。
15.RPUSHX key value
将值 value 插入到列表 key 的表尾,当且仅当 key
和 RPUSH 命令相反,当 key
可用版本:
>= 2.2.0
时间复杂度:
O(1)
返回值:
RPUSHX 命令执行之后,表的长度。