Redis实现UV统计的示例代码

 更新时间:2023年01月29日 15:42:38   作者:卒获有所闻  
本文主要介绍了Redis实现UV统计的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

一、HyperLogLog

1、为什么用HyperLogLog

先介绍两个概念:

UV:全称 Unique Visitor,也叫独立访客量,是指通过互联网访问、浏览这个网页的自然人、1 天内同一个用户多次访问该网站,只记录 1 次。
PV:全称 Page View,也叫页面访问量或点击量,用户每访问网站的一个页面,记录一次 PV,用户多次打开页面,则记录多次 PV。往往用来衡量网站的流量。

UV 统计在服务端做会比较麻烦,因为要判断该用户是否已经统计过了,需要将统计过的用户信息保存。但是如果每个访问的用户都保存到Redis 中,数据量会非常恐怖。

那么我们要怎么更好的记录呢?就用到 HyperLogLog

2、HyperLogLog是什么

HyperLogLog(HLL)是从 Loglog 算法派生的概率算法,用于确定非常大的集合的基数,而不需要存储其所有值。

Redis 中的 HLL 是基于 String 结构实现的,单个 HLL 的内存永远小于 16kb,内存占用低的令人发指!作为代价,其测量结果是概率性的,有小于 0.81% 的误差。不过对于 UV 统计来说,这完全可以忽略。

不管加入多少重复元素,HyperLogLog都只记录一次,天生适合做uv的统计

二、实现UV统计

我们直接用单元测试,向 HyperLogLog 中添加 100 万条数据,看看内存占用和统计效果如何:

@Test
void testHyperLogLog() {
    String[] values = new String[1000];
    int j = 0;
    for (int i = 0; i < 1000000; i++) {
        j = i % 1000;
        values[j] = "user_" + i;
        if(j == 999){
            // 发送到 Redis
            stringRedisTemplate.opsForHyperLogLog().add("hl2", values);
        }
    }
    // 统计数量
    Long count = stringRedisTemplate.opsForHyperLogLog().size("hl2");
    System.out.println("count = " + count);
}

测试结果:

我们统计出来的数据跟100万非常接近,误差在0.02。而且发现内存只消耗了14kb非常非常低

到此这篇关于Redis实现UV统计的示例代码的文章就介绍到这了,更多相关Redis UV统计内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Redis RDB快照持久化及写操作禁止问题排查与解决

    Redis RDB快照持久化及写操作禁止问题排查与解决

    本文主要介绍了Redis RDB快照持久化及写操作禁止问题排查与解决,由于 stop-writes-on-bgsave-error 选项处于启用状态,所以写操作被禁止,下面就来介绍一下,感兴趣的可以了解一下
    2025-04-04
  • 使用Redis实现实时排行榜功能

    使用Redis实现实时排行榜功能

    排行榜功能是一个很普遍的需求。使用 Redis 中有序集合的特性来实现排行榜是又好又快的选择。接下来通过本文给大家介绍使用Redis实现实时排行榜功能,需要的朋友可以参考下
    2021-07-07
  • Redis慢查询日志与监视器问题

    Redis慢查询日志与监视器问题

    这篇文章主要介绍了Redis慢查询日志与监视器问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-12-12
  • 基于 Spring Aop 环绕通知实现 Redis 缓存双删功能(示例代码)

    基于 Spring Aop 环绕通知实现 Redis 缓存双删功能(示例代码)

    基于 spring aop 常规应用场景多是用于日志记录以及实现 redis 分布式锁,在 github 中也有项目是把它拿来当作缓存的异常捕捉,这篇文章主要介绍了基于 Spring Aop 环绕通知实现 Redis 缓存双删,需要的朋友可以参考下
    2022-08-08
  • Redis SCAN命令详解

    Redis SCAN命令详解

    SCAN 命令是一个基于游标的迭代器,每次被调用之后, 都会向用户返回一个新的游标, 用户在下次迭代时需要使用这个新游标作为 SCAN 命令的游标参数, 以此来延续之前的迭代过程,这篇文章给大家介绍了Redis SCAN命令的相关知识,感兴趣的朋友一起看看吧
    2022-07-07
  • Redis中的连接命令与键命令操作详解

    Redis中的连接命令与键命令操作详解

    Redis连接命令主要是用于客户端与服务器建立连接的,Redis是一种流行的内存数据库,支持多种数据结构,其中键命令是核心操作之一,在Redis中,键(Key)是用来存储数据的主要元素,每个键都有一个唯一的名称,本文给大家介绍了Redis中的连接命令与键命令操作
    2024-09-09
  • Redis高并发缓存问题分析及解决过程

    Redis高并发缓存问题分析及解决过程

    文章总结了Redis缓存的六种常见问题及其解决方案:缓存穿透、缓存击穿、缓存雪崩、热点key重建优化、缓存和数据库双写不一致,以及Redis对过期key的三种清除策略,每种问题都提供了详细的原因分析和具体的解决方案
    2025-01-01
  • Redis中Zset类型常用命令的实现

    Redis中Zset类型常用命令的实现

    Zset是Redis的一种有序集合数据类型,Zset通过压缩列表和跳跃表两种底层编码方式支持小数据集和大数据集,支持多种操作,包括添加、查询、删除元素以及集合运算等,具有不同的时间复杂度,感兴趣的可以了解一下
    2024-10-10
  • Redis缓冲区溢出及解决方案分享

    Redis缓冲区溢出及解决方案分享

    Redis缓冲区溢出是指Redis缓冲区被写入的数据超过了它的容量,导致数据无法存储或被覆盖。造成缓冲区溢出的原因可能是快速写入大量数据、缓冲区未及时刷新或Redis服务器配置不当等。
    2023-04-04
  • Redis分片集群的实现

    Redis分片集群的实现

    Redis 分片集群是一种将 Redis数据库分散到多个节点上的方式,以提供更高的性能和可伸缩性,本文主要介绍了Redis分片集群的实现,具有一定的参考价值,感兴趣的可以了解一下
    2025-04-04

最新评论