Spring Boot整合WebSocket和Redis实现直播间在线人数统计功能
创始人
2025-01-15 06:33:49
0

在这里插入图片描述

😄 19年之后由于某些原因断更了三年,23年重新扬帆起航,推出更多优质博文,希望大家多多支持~
🌷 古之立大事者,不惟有超世之才,亦必有坚忍不拔之志
🎐 个人CSND主页——Micro麦可乐的博客
🐥《Docker实操教程》专栏以最新的Centos版本为基础进行Docker实操教程,入门到实战
🌺《RabbitMQ》专栏主要介绍使用JAVA开发RabbitMQ的系列教程,从基础知识到项目实战
🌸《设计模式》专栏以实际的生活场景为案例进行讲解,让大家对设计模式有一个更清晰的理解
💕《Jenkins实战》专栏主要介绍Jenkins+Docker的实战教程,让你快速掌握项目CI/CD,是2024年最新的实战教程
🌞《Spring Boot》专栏主要介绍我们日常工作项目中经常应用到的功能以及技巧,代码样例完整
如果文章能够给大家带来一定的帮助!欢迎关注、评论互动~

Spring Boot整合WebSocket和Redis实现直播间在线人数统计功能

  • 前言
  • 简单了解WebSocket和Redis
  • 开发准备
    • 步骤一:添加依赖
    • 步骤二:配置Redis
    • 步骤三:定义WebSocket处理器
    • 步骤四:编写WebSocket配置类
    • 步骤五:编写简单的前端页面
  • 开始测试
  • 总结

前言

在现在这个短视频时代,很多企业也投入到了直播的行业,甚至为了打造自己专属私域某些企业也会开发应用自己的直播系统,而在直播应用中,实时显示在线人数是一个非常重要的功能。

这里博主将详细介绍通过结合 Spring BootWebSocketRedis ,我们可以实现一个简单而高效的直播间在线人数统计功能,并提供完整的代码示例。

简单了解WebSocket和Redis

WebSocket是一种在单个TCP连接上进行全双工通信的协议,适用于需要实时数据更新的应用。Redis是一个高性能的键值存储系统,常用于缓存和消息队列。在这里博主将将使用WebSocket来监控用户的连接状态,并使用 Redis 来存储和统计在线人数。

开发准备

步骤一:添加依赖

首先构建我们的 Spring Boot 项目, 引入相关依赖 WebSocketRedis 的依赖

 	         org.springframework.boot         spring-boot-starter-web                   org.springframework.boot         spring-boot-starter-websocket                   org.springframework.boot         spring-boot-starter-data-redis       

步骤二:配置Redis

由于Spring Boot自动装配的原理,我们只需要在配置文件设置 Redis 的连接参数,在需要使用Redis的地方注入 RedisTemplate 即可

spring:     #redis     redis:         # 地址         host: 127.0.0.1         # 端口,默认为6379         port: 6379         # 数据库索引         database: 0         # 密码         password:         # 连接超时时间         timeout: 10s         lettuce:             pool:                 # 连接池中的最小空闲连接                 min-idle: 5                 # 连接池中的最大空闲连接                 max-idle: 8                 # 连接池的最大数据库连接数                 max-active: 20                 # #连接池最大阻塞等待时间(使用负值表示没有限制)                 max-wait: -1ms 

步骤三:定义WebSocket处理器

创建一个 WebSocket理器类WebSocketHandler继承TextWebSocketHandler,用于处理WebSocket消息和连接事件

package com.toher.dockertestproject.live;  import org.springframework.data.redis.core.StringRedisTemplate; import org.springframework.stereotype.Component; import org.springframework.web.socket.CloseStatus; import org.springframework.web.socket.TextMessage; import org.springframework.web.socket.WebSocketSession; import org.springframework.web.socket.handler.TextWebSocketHandler;  import java.util.Collections; import java.util.Map; import java.util.Set; import java.util.concurrent.ConcurrentHashMap;  @Component public class WebSocketHandler extends TextWebSocketHandler {      //定义redis key     private static final String LIVE_ROOM_USER_KEY = "liveRoomUsers";     //注入RedisTemplate     private final StringRedisTemplate redisTemplate;     //使用集合存储每个用户WebSocket会话     private final Set sessions = Collections.newSetFromMap(new ConcurrentHashMap<>());      public WebSocketHandler(StringRedisTemplate redisTemplate) {         this.redisTemplate = redisTemplate;     }      /**      * 建立连接后      * @param session 连接会话      * @throws Exception      */     @Override     public void afterConnectionEstablished(WebSocketSession session) throws Exception {         sessions.add(session);         //调用increment方法进行自增操作         redisTemplate.opsForValue().increment(LIVE_ROOM_USER_KEY);     }      @Override     protected void handleTextMessage(WebSocketSession session, TextMessage message) throws Exception {         String userId = message.getPayload();         // 拟获取用户Id 后返回用户信息         String userName = "匿名用户";         if(userId.equals("1")){             userName = "榜一大哥:小明";         }         if(userId.equals("2")){             userName = "榜二大姐:小羊";         }         session.sendMessage(new TextMessage("user:"+userName));         broadcastOnlineCount();     }      @Override     public void afterConnectionClosed(WebSocketSession session, CloseStatus status) throws Exception {         //集合删除会话         sessions.remove(session);         //调用increment方法进行自减操作         redisTemplate.opsForValue().decrement(LIVE_ROOM_USER_KEY);         broadcastOnlineCount();     }      private void broadcastOnlineCount() {         String count = redisTemplate.opsForValue().get(LIVE_ROOM_USER_KEY);         TextMessage message = new TextMessage("count: " + count);         for (WebSocketSession session : sessions)             try {                 session.sendMessage(message);             } catch (Exception e) {                 e.printStackTrace();             }     } } 

步骤四:编写WebSocket配置类

定义 WebSocket 配置类,并添加注解 @EnableWebSocket 开启 WebSocket 支持

import org.springframework.context.annotation.Configuration; import org.springframework.web.socket.config.annotation.EnableWebSocket; import org.springframework.web.socket.config.annotation.WebSocketConfigurer; import org.springframework.web.socket.config.annotation.WebSocketHandlerRegistry;  @Configuration @EnableWebSocket public class WebSocketConfig implements WebSocketConfigurer {      //注入WebSocket处理器     private final WebSocketHandler webSocketHandler;      public WebSocketConfig(WebSocketHandler webSocketHandler) {         this.webSocketHandler = webSocketHandler;     }      @Override     public void registerWebSocketHandlers(WebSocketHandlerRegistry registry) {         registry.addHandler(webSocketHandler, "/ws")                 .setAllowedOrigins("*");     } } 

步骤五:编写简单的前端页面

创建一个简单的前端页面,URL传递参数用户ID用于模拟后端获取用户信息返回,创建一个id元素用于连接WebSocket并显示在线人数

       欢迎来到麦可乐的直播间       

直播间人数: 0

开始测试

将前后端项目运行,打开多个浏览器窗口(不是标签页!不是标签页!不是标签页!),测试访问
在这里插入图片描述

可以看到如上图所示,当新窗口进入了前端地址直播间人数+1,关闭窗口或所在标签页直播间人数-1

总结

通过本文的步骤,我们成功地在Spring Boot项目整合WebSocket和Redis实现了一个直播间在线人数统计功能。这个解决方案不仅能够实时更新在线人数,还能有效地处理高并发场景。
本文的代码主要是演示使用,小伙伴们可以根据自己业务需求进行修改升级。如果本文对您有所帮助,希望 一键三连 给博主一点点鼓励,如果您有任何疑问或建议,请随时留言讨论。


在这里插入图片描述

相关内容

热门资讯

第一分钟了解!wepoker安... 第一分钟了解!wepoker安装教程(透视)外挂透视辅助第一(原来有挂)1)wepoker安装教程辅...
记者爆料!边锋小程序辅助脚本免... 记者爆料!边锋小程序辅助脚本免费,微乐小程序免费黑科技(详细辅助解密教程)1、边锋小程序辅助脚本免费...
透视辅助"关春天凑一... 透视辅助"关春天凑一桌游戏辅助器"详细辅助必胜教程(其实是真的有挂)关春天凑一桌游戏辅助器是一种具有...
第一分钟了解!德扑圈透视(透视... 第一分钟了解!德扑圈透视(透视)外挂透视辅助第一(好像有挂)1、每一步都需要思考,不同水平的挑战会更...
我来分享!传送屋辅助软件下载最... 我来分享!传送屋辅助软件下载最新版本更新内容,闲逸辅助功能怎么下载(详细辅助透明挂教程)是一款可以让...
透视有挂"菠萝辅助a... 透视有挂"菠萝辅助app"详细辅助存在挂教程(果然是真的有挂)1、进入游戏-大厅左侧-新手福利-激活...
六分钟了解!we poker游... 六分钟了解!we poker游戏下(透视)外挂透视辅助六(本来存在有挂)1、金币登录送、破产送、升级...
重大通报!科乐辅助功能插件,传... 重大通报!科乐辅助功能插件,传送屋激k看底牌辅助软件(详细辅助透明挂教程)您好,传送屋激k看底牌辅助...
透视教学"闲逸辅助软... 透视教学"闲逸辅助软件"详细辅助爆料教程(真是真的是有挂)1、游戏颠覆性的策略玩法,独创攻略技巧玩法...
九分钟了解!werplan怎么... 九分钟了解!werplan怎么透视(透视)外挂透视辅助九(原来真的有挂);1、进入到werplan怎...