Redis: HyperLogLog
HyperLogLog 是用来做基数统计的算法,它提供不精确去重计数方案,标准误差是0.81%。 常用命令如下:
这里查看 示例:
package main
import (
	"context"
	"fmt"
	"github.com/redis/go-redis/v9"
)
func main() {
	ctx := context.Background()
	rdb := redis.NewClient(&redis.Options{
		Addr: ":6379",
	})
	_ = rdb.FlushDB(ctx).Err()
	for i := 0; i < 10; i++ {
		if err := rdb.PFAdd(ctx, "myset", fmt.Sprint(i)).Err(); err != nil {
			panic(err)
		}
	}
	card, err := rdb.PFCount(ctx, "myset").Result()
	if err != nil {
		panic(err)
	}
	fmt.Println("set cardinality", card)
}