iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >怎么在SpringBoot中使用Redis统计在线用户信息
  • 812
分享到

怎么在SpringBoot中使用Redis统计在线用户信息

2023-06-14 20:06:48 812人浏览 安东尼
摘要

怎么在SpringBoot中使用Redis统计在线用户信息?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。springboot是什么springboot一种全新的

怎么在SpringBoot中使用Redis统计在线用户信息?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

springboot是什么

springboot一种全新的编程规范,其设计目的是用来简化新Spring应用的初始搭建以及开发过程,SpringBoot也是一个服务于框架的框架,服务范围是简化配置文件。

基于数据库实现

最简单的办法,就是在用户表,添加一个最后心跳包的日期时间字段 last_active。服务器收到心跳后,每次都去更新这个字段为当前的最新时间。

如果要查询最近5分钟活跃的用户数量,就可以简单的通过一句sql完成。

SELECT COUNT(1) AS `online_user_count` FROM `user` WHERE `last_active` BETWEEN  '2020-12-22 13:00:00' AND '020-12-22 13:05:00';

弊端也是显而易见,为了提高检索效率,不得不为last_active字段添加索引,而因为心跳的更新,会导致频繁的重新维护索引树,效率极其低下。

基于Redis实现

这是比较理想的一种实现方式了,Redis基于内存进行读写,性能自然比关系型数据库好得多,而且它所提供的Zset可以很方便的构建出一个在线用户的统计服务。

Redis的Zset

这里不会涉及太多redis的东西,简单说明以下zset。它是一个有序的set集合,集合中的每个元素由2个东西组成

  • member 既然是集合,那么它便是集合中的元素,并且不能重复

  • score  既然是有序的,它就是用于排序的权重字段

Zset的部分操作

添加元素

ZADD key score member [score member ...]

一次性添加一个或者多个元素到集合,如果member已经存在则会使用当前score进行覆盖

统计所有的元素数量

ZCARD key

统计score值在min和max之间元素数量

ZCOUNT key min max

删除score值在min和max之间的元素

ZREMRANGEBYSCORE key min max

一个示例

我打算,用一个zset存储我内心中编程语言的评分排名,这个key叫做lang

添加信息,返回新添加的元素个数

> zadd lang 999 PHP 10 java 9 Go 8 python 7 javascript"5"

查看添加的数量

> zcard lang"5"

查看评分在8 - 10之间的元素个数,有3个

> zcount lang 8 10"3"

删除评分在8 - 1000的元素,返回删除的个数

> ZREMRANGEBYSCORE lang 8 1000"4"

在线用户服务的实现

知道了zset后,就可以实现一个在线用户的统计服务了。

实现思路

客户端每隔5分钟发送一个心跳到服务器,服务器根据会话获取到用户的ID,作为zset的member
存入zset,score便是当前收到心跳的时间戳,当同一个用户第二次发送心跳的时候,就会更新他对应的score值,由于更新是在内存,这个速度相当快。

zadd users 1608616915109 10000

需要统计出在线用户的数量,本质上就是需要统计出,最近5分钟有发送心跳的用户,通过zcount可以很轻松的统计出来。通过程序获取到当前的时间戳,作为maxScore,时间戳减去5分钟后作为minScore。

zcount users 1608616615109 1608616915109

因为某些用户可能长时间没有登录过了,可以通过ZREMRANGEBYSCORE进行清理。通过程序获取到当前的时间戳,减去5分钟后作为maxScore,使用0, 作为minScore,表示清理所有超过5分钟没有发送过心跳包的用户。

ZREMRANGEBYSCORE users 0 1608616615109

实现代码

import java.time.Duration;import java.time.Instant;import java.time.LocalDateTime;import java.time.ZoneId;import javax.annotation.Resource;import org.springframework.data.redis.core.StringRedisTemplate;import org.springframework.stereotype.Component;@Componentpublic class OnlineUserStatsService {        private static final String ONLINE_USERS = "onlie_users";    @Resource    private StringRedisTemplate stringRedisTemplate;        public Boolean online(Integer userId) {        return this.stringRedisTemplate.opsForZSet().add(ONLINE_USERS, userId.toString(), Instant.now().toEpochMilli());    }            public Long count(Duration duration) {        LocalDateTime now = LocalDateTime.now();        return this.stringRedisTemplate.opsForZSet().count(ONLINE_USERS,                                     now.minus(duration).atZone(ZoneId.systemDefault()).toInstant().toEpochMilli(),                                     now.atZone(ZoneId.systemDefault()).toInstant().toEpochMilli());    }            public Long count() {        return this.stringRedisTemplate.opsForZSet().zCard(ONLINE_USERS);    }            public Long clear(Duration duration) {        return this.stringRedisTemplate.opsForZSet().removeRangeByScore(ONLINE_USERS, 0,                 LocalDateTime.now().minus(duration).atZone(ZoneId.systemDefault()).toInstant().toEpochMilli());    }}

使用示例

@Resourceprivate OnlineUserStatsService onlineUserStatsService;@Testpublic void test() {        // ID为1的用户发送了心跳包    boolean result = this.onlineUserStatsService.online(1);    System.out.println("online=" + result);        // 获取5分钟内,发送过心跳包的用户数量,也就是在线用户的数量    Long count = this.onlineUserStatsService.count(Duration.ofMinutes(5));    System.out.println("oneline count=" + count);        // 获取所有发送过心跳包的用户数量    count = this.onlineUserStatsService.count();    System.out.println("all count=" + count);        // 清除超过1天都没发送过心跳包的用户    Long clear = this.onlineUserStatsService.clear(Duration.ofDays(1));    System.out.println("clear=" + clear);}

内存消耗分析

可以通过 Http://www.redis.cn/redis_memory/ 预算Redis的内存消耗

我对Redis的内存分配并不熟悉,只是按照自己的想法去填写了一些数据,所以我在这里理解的东西,可能是错误的。但是我想这并不耽误证明 - 在这种场景使用Zset对内存消耗极低的事实

设想onlie_users需要存储1亿个用户的状态信息,每个元素score和member需要10个字节存储,那么一共大约需要20G内存。20G的内存对于现在的服务器来说,并不是大问题。

怎么在SpringBoot中使用Redis统计在线用户信息

最后

  • 心跳协议不一定非要HTTP,如果客户端支持的话UDP就很适合,可以节约一些系统开销。

  • zset的key,不一定非要用String,可以修改序列化方式,以固定的字节的形式存储用户ID,在用户ID过大的时候,可以节约一些存储空间。

String userId = "10010";System.out.println(userId.getBytes().length); // 以字符串形式存储 => 需要5个字节byte[] bin = ByteBuffer.allocate(4).putInt(Integer.valueOf(userId)).array();System.out.println(bin.length);                    // 序列化为字节形式存储 => 需要4个字节System.out.println(ByteBuffer.wrap(bin).getInt());    // 反序列化为ID => 10010

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注编程网精选频道,感谢您对编程网的支持。

--结束END--

本文标题: 怎么在SpringBoot中使用Redis统计在线用户信息

本文链接: https://www.lsjlt.com/news/275068.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么在SpringBoot中使用Redis统计在线用户信息
    怎么在SpringBoot中使用Redis统计在线用户信息?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。springboot是什么springboot一种全新的...
    99+
    2023-06-14
  • SpringBoot使用Redis的zset统计在线用户信息
    目录在线用户统计的实现 基于数据库实现 基于Redis实现 Redis的Zset Zset的部分操作 一个示例 在线用户服务的实现 实现思路 使用示例内存消耗分析 最后 统计在线用户...
    99+
    2024-04-02
  • SpringSession怎么通过Redis统计在线用户数量
    这篇“SpringSession怎么通过Redis统计在线用户数量”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Spring...
    99+
    2023-07-05
  • 怎么在springboot中用redis实现消息队列
    本篇内容主要讲解“怎么在springboot中用redis实现消息队列”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么在springboot中用redis实现消息队列”吧!准备阶段安装redi...
    99+
    2023-06-19
  • 怎么在Linux系统中使用who和whoami命令获取用户信息
    这期内容当中小编将会给大家带来有关怎么在Linux系统中使用who和whoami命令获取用户信息,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。who用法:who [选项]... [ 文件 | 参数1 参数...
    99+
    2023-06-12
  • 怎么在Oracle中导出导入统计信息
    怎么在Oracle中导出导入统计信息?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。schema级别统计信息的导出导入  通过调...
    99+
    2024-04-02
  • SpringSession通过Redis统计在线用户数量的实现代码
    最近遇到一个比较紧急的任务,要求统计在线用户,目的是配合性能测评,要求证明自己系统的在线用户能够达标,不过系统因为历史原因,并没有这个功能,所以只能去springSession官网和网上搜资料,想到通过统计Redis里缓...
    99+
    2023-04-07
    Redis在线用户数量 SpringSession Redis在线用户
  • Redis中怎么用setbit统计活跃用户
    这篇文章主要讲解了“Redis中怎么用setbit统计活跃用户”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Redis中怎么用setbit统计活跃用户”吧!...
    99+
    2024-04-02
  • 怎么在Linux系统中获取无线网卡信息
    这篇文章将为大家详细讲解有关怎么在Linux系统中获取无线网卡信息,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。iwpriv配置连接选项命令例:代码如下:[root@linux ~]# iw...
    99+
    2023-06-12
  • 如何在CentOS中使用netstat命令查看网络统计信息
    要在CentOS中使用netstat命令查看网络统计信息,可以按照以下步骤操作: 打开终端窗口,输入以下命令来查看所有网络连接的统...
    99+
    2024-04-02
  • 在Linux系统中如何显示已知的用户信息
    这篇文章给大家分享的是有关在Linux系统中如何显示已知的用户信息的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。在Linux系统中显示已知的用户信息只要输入:## linux 版本 ...
    99+
    2023-06-27
  • 怎么在Win10系统中使用命令查看激活信息
    本篇文章为大家展示了怎么在Win10系统中使用命令查看激活信息,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。详细如下:一、“win+R“,开启运行窗口,输入“cmd”,回车。二、我们可以使用 slm...
    99+
    2023-06-07
  • SpringBoot和redis中怎么使用Lettuce客户端
    这篇文章给大家介绍SpringBoot和redis中怎么使用Lettuce客户端,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。重写连接工厂实例,更改其LettuceClientConfiguration 为开启拓扑更新...
    99+
    2023-06-20
  • Redis在在线教育系统中的作用及应用
    Redis在在线教育系统中的作用及应用,需要具体代码示例随着在线教育的兴起,大量的用户数据、课程数据、订单数据等海量数据需要被高效地存储和管理。而Redis作为一款高性能、内存型的数据库,正好可以满足在线教育系统的性能和可用性要求。本文将介...
    99+
    2023-11-07
    缓存 分布式 高性能
  • 怎么在SpringBoot中使用Redis实现分布式锁
    这篇文章主要介绍了怎么在SpringBoot中使用Redis实现分布式锁的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇怎么在SpringBoot中使用Redis实现分布式锁文章都会有所收获,下面我们一起来看看吧...
    99+
    2023-07-05
  • 怎么在SpringBoot项目中使用redis工具jar包
    本篇文章为大家展示了怎么在SpringBoot项目中使用redis工具jar包,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。一、Redis常用存储操作实现(redis-util模块,该module最...
    99+
    2023-06-08
  • Redis中怎么统计独立用户访问量
    Redis中怎么统计独立用户访问量,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。使用Hash哈希是Redis的一种基础数据结构,Redis...
    99+
    2024-04-02
  • 怎么在Linux系统中使用lsblk和blkid显示设备信息
    这篇文章主要讲解了“怎么在Linux系统中使用lsblk和blkid显示设备信息”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么在Linux系统中使用lsblk和blkid显示设备信息”吧...
    99+
    2023-06-13
  • 怎么在SpringBoot中使用nacos
    怎么在SpringBoot中使用nacos?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、什么是nacosnacos支持基于dns和基于rpc的服务发现,可以作为spri...
    99+
    2023-06-15
  • rabbitmq怎么在springboot中使用
    rabbitmq怎么在springboot中使用?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。概述RabbitMQ是一个开源的消息代理和队列服务器,用来通过普通协议在完全不同的...
    99+
    2023-05-30
    springboot rabbitmq
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作