redis 四
Redis 有序集合(sorted set) Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员。 不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。 有序集合的成员是唯一的,但分数(score)却可以重复。 集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。 集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。 zadd key score1 member1 [score2 member2] :向有序集合添加一个或多个成员,或者更新已存在成员的分数 zcard key :获取有序集合的成员数 zcount key min max :计算在有序集合中指定区间分数的成员数 zincrby key increment member :有序集合中对指定成员的分数加上增量 increment zinterstore destination numkeys key [key...] :计算给定的一个或多个有序集的交集并将结果集存储在新的有序集合 key 中 zlexcount key min max :在有序集合中计算指定字典区间内成员数量 zrange key start stop [withscores] :通过索引区间返回有序集合成指定区间内的成员 zrangebylex key min max [limit offset count] :通过字典区间返回有序集合的成员 zrangebyscore key min max [withscores][limit] :通过分数返回有序集合指定区间内的成员 zrank key member :返回有序集合中指定成员的索引 zrem key member [member...] :移除有序集合中的一个或多个成员 zremrangebylex key min max :移除有序集合中给定的字典区间的所有成员 zremrangebyrank key start stop :移除有序集合中给定的排名区间的所有成员 zremrangebyscore key min max :移除有序集合中给定的分数区间的所有成员 zrevrange key start stop [withscores] :返回有序集中指定区间内的成员,通过索引,分数从高到底 zrevrangebyscore key max min [withscores] :返回有序集中指定分数区间内的成员,分数从高到低排序 zrevrank key member :返回有序集合中指定成员的排名,有序集成员按分数值递减(从大到小)排序 zscore key member :返回有序集中,成员的分数值 zunionstore destination numkeys key [key...] :计算给定的一个或多个有序集的并集,并存储在新的 key 中 zscan key cursor [match pattern] [COUNT count] :迭代有序集合中的元素(包括元素成员和元素分值) Redis HyperLogLog Redis 在 2.8.9 版本添加了 HyperLogLog 结构。 Redis HyperLogLog 是用来做基数统计的算法,HyperLogLog 的优点是,在输入元素的数量或者体积非常非常大时,计算基数所需的空间总是固定 的、并且是很小的。 在 Redis 里面,每个 HyperLogLog 键只需要花费 12 KB 内存,就可以计算接近 2^64 个不同元素的基 数。这和计算基数时,元素越多耗费内存就越多的集合形成鲜明对比。 但是,因为 HyperLogLog 只会根据输入元素来计算基数,而不会储存输入元素本身,所以 HyperLogLog 不能像集合那样,返回输入的各个元素。 什么是基数? 比如数据集 {1, 3, 5, 7, 5, 7, 8}, 那么这个数据集的基数集为 {1, 3, 5 ,7, 8}, 基数(不重复元素)为5。 基数估计就是在误差可接受的范围内,快速计算基数。 Redis HyperLogLog 命令 pfadd key element [element...] :添加指定元素到 HyperLogLog 中。 pfcount key [key...] :返回给定 HyperLogLog 的基数估算值。 pfmerge destkey sourcekey [sourcekey...] :将多个 HyperLogLog 合并为一个 HyperLogLog Redis 发布订阅 Redis 发布订阅(pub/sub)是一种消息通信模式:发送者(pub)发送消息,订阅者(sub)接收消息。 Redis 客户端可以订阅任意数量的频道。 下图展示了频道 channel1 , 以及订阅这个频道的三个客户端 —— client2 、 client5 和 client1 之间的关系:当有新消息通过 PUBLISH 命令发送给频道 channel1 时, 这个消息就会被发送给订阅它的三个客户端:
实例 以下实例演示了发布订阅是如何工作的。在我们实例中我们创建了订阅频道名为 redisChat: redis 127.0.0.1:6379> SUBSCRIBE redisChat Reading messages... (press Ctrl-C to quit) 1) "subscribe" 2) "redisChat" 3) (integer) 1 现在,我们先重新开启个 redis 客户端,然后在同一个频道 redisChat 发布两次消息,订阅者就能接收到消息。 redis 127.0.0.1:6379> PUBLISH redisChat "Redis is a great caching technique" (integer) 1 redis 127.0.0.1:6379> PUBLISH redisChat "Learn redis by runoob.com" (integer) 1 # 订阅者的客户端会显示如下消息 1) "message" 2) "redisChat" 3) "Redis is a great caching technique" 1) "message" 2) "redisChat" 3) "Learn redis by runoob.com" Redis 发布订阅命令 psubscribe pattern [pattern...] :订阅一个或多个符合给定模式的频道。 pubsub subcommand [argument [argument...]] :查看订阅与发布系统状态。 publish channel message :将信息发送到指定的频道。 punsubscribe [pattern [pattern...]] :退订所有给定模式的频道。 subscribe channel [channel...] :订阅给定的一个或多个频道的信息。 unsubscribe [channel [channel...]] :指退订给定的频道。