Redis实战案例27-UV统计

1. Redis的HyperLogLog的统计功能


示例:

表明HyperLogLog不管加入重复元素多少次都不会让count++,不会计数重复元素,所以适合做UV计数

2. 简单实现UV测试

通过单元测试,向 HyperLogLog 中添加 100 万条数据,看看内存占用和统计效果如何

java 复制代码
/**
 * UV统计测试
 */
@Test
void testHyperLogLog() {
    String[] values = new String[1000];
    int j = 0;
    //分批·每次一千导入到Redis中
    for (int i = 0; i < 1000000; i++) {
        j = i % 1000;
        values[j] = "user_" + i;
        if(j == 999) {
            // 发送到Redis中
            stringRedisTemplate.opsForHyperLogLog().add("hl1", values);
        }
    }
    // 统计数量
    Long count = stringRedisTemplate.opsForHyperLogLog().size("hl1");
    System.out.println("count = " + count);
}

插入了一百万条,最后得到的是997573条,符合概率预期

再次查看内存消耗

相关推荐
一只小白0009 小时前
Redis 常用命令总结
数据库·redis·缓存
Han.miracle10 小时前
Redis 全套笔记:基础 API + 三大架构 + 缓存三大问题
java·windows·redis
风吹迎面入袖凉10 小时前
【Redis】Redis缓存击穿
数据库·redis·缓存
小飞鱼通达二开12 小时前
[学习笔记]Redis概述
redis
老毛肚14 小时前
Redis高级
java·数据库·redis
几度热忱14 小时前
【uv包管理工具】常用命令记录
python·uv
kiku181815 小时前
NoSQL之Redis集群
数据库·redis·nosql
indexsunny15 小时前
互联网大厂Java面试实录:微服务+Spring Boot在电商场景中的应用
java·spring boot·redis·微服务·eureka·kafka·spring security
卢傢蕊16 小时前
NoSQL 之Redis 集群
数据库·redis·nosql
霸道流氓气质16 小时前
Bat中实现简单运维脚本示例-启动redis、检测指定端口是否占用、占用则杀死进程、等待指定秒数、启动jar包
运维·redis·jar