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

浙公网安备 33010602011771号