HyperLogLog(用于计算基数)

hyperLogLog的概述

Redis 中的HyperLogLog是用来做基数(在一个集合中,不重复的元素)统计的算法。

Redis的优点是,在输入元素的数量或者体积非常非常大时,计算基数所需的空间总是固定的。并且是很小的。

每个HyperLogLog键只需要花费12KB内存,就可以计算接近2^64个不同元素的基数。因为HyperLogLog只会根据输入元素来计算基数,而不会储存输入元素本身,所以HyperLogLog不能像集合那样,返回输入的各个元素

HyperLogLog命令

127.0.0.1:6379> pfadd ele java  # 添加指定元素到HyperLogLog
(integer) 1
127.0.0.1:6379> pfadd ele c++ Cpp
(integer) 1
127.0.0.1:6379> pfadd python php
(integer) 1
127.0.0.1:6379> pfcount ele  # 统计HyperLOgLOg中基数的总量
(integer) 3
127.0.0.1:6379> pfcount python
(integer) 1
127.0.0.1:6379> pfmerge ele1 ele python # 将两个Hyper的基数加入到另一个Hyper中
OK
127.0.0.1:6379> pfcount ele1
(integer) 4
127.0.0.1:6379> type ele1
string
127.0.0.1:6379> type ele
string
posted @ 2022-06-02 19:51  小罗要有出息  阅读(59)  评论(0)    收藏  举报