一、用户签到:BitMap功能
代表某个用户某一天的签到记录;如果有1000万用户,平均没人每年签到10次,一年则为1亿条;数据庞大;也耗内存;
data:image/s3,"s3://crabby-images/72da1/72da1dfe1ec0749a17411074cbfd4926c7771ea3" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/c1071/c1071a51f299c8c5f3d176b3fe23526d0525f9f3" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/c531c/c531cc31c392fa9be0ffdf7791eca3e590b3095b" alt="在这里插入图片描述"
二、用户签到:实现签到功能
data:image/s3,"s3://crabby-images/20fc7/20fc762b7055adae770971045ad72f89fd48de98" alt="在这里插入图片描述"
@Override
public Result sign() {
UserDTO user = UserHolder.getUser();
Long userId = user.getId();
LocalDateTime now = LocalDateTime.now();
String keySuffix = now.format(DateTimeFormatter.ofPattern(":yyyyMM"));
String key = com.hmdp.utils.RedisConstants.USER_SIGN_KEY + userId + keySuffix;
int dayOfMonth = now.getDayOfMonth();
redisTemplate.opsForValue().setBit(key,dayOfMonth - 1,true);
return Result.ok();
}
三、连续签到统计
data:image/s3,"s3://crabby-images/bb247/bb24766199e24321a6ed260c2d11d6639de07e3e" alt="在这里插入图片描述"
@Override
public Result signCount() {
Long userId = UserHolder.getUser().getId();
LocalDateTime now = LocalDateTime.now();
String keySuffix = now.format(DateTimeFormatter.ofPattern(":yyyyMM"));
String key = USER_SIGN_KEY + userId + keySuffix;
int dayOfMonth = now.getDayOfMonth();
List<Long> result = redisTemplate.opsForValue().bitField(
key,
BitFieldSubCommands.create()
.get(BitFieldSubCommands.BitFieldType.unsigned(dayOfMonth)).valueAt(0)
);
if (result == null || result.isEmpty()) {
return Result.ok(0);
}
Long num = result.get(0);
if (num == null || num == 0) {
return Result.ok(0);
}
int count = 0;
while (true) {
if ((num & 1) == 0) {
break;
}else {
count++;
}
num >>>= 1;
}
return Result.ok(count);
}
四、UV统计
UV:unique vistitor :独立访客量,指通过互联网访问、浏览网页的自然人。1天内同一个用户多次访问该网站,只记录1次。 PV:page view.页面访问量或者点击量,用户每访问一个页面,记录1次叫pv。往往用来衡量网站的流量。 data:image/s3,"s3://crabby-images/7a821/7a8216eccffe6e09723d446a704acde04d62d4ff" alt="在这里插入图片描述"
五、UV统计实现:百万数据
@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){
stringRedisTemplate.opsForHyperLogLog().add("hl2", values);
}
}
Long count = stringRedisTemplate.opsForHyperLogLog().size("hl2");
System.out.println("count = " + count);
}
|