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


在这里插入图片描述

相关内容

热门资讯

XML Schema 杂项数据... XML Schema 杂项数据类型XML Schema 提供了多种数据类型,用于定义 XML 文档中...
Html5前端基本知识整理与回... 今天我们继续结合发布的Html5基础知识点文档进行复习,希望对大家有所帮助。目录列表无...
数据结构练习 1.快速排序的非递归是通过栈来实现的,则前序与层次可以通过控制入栈的顺序来实现...
AJAX学习笔记上(学习自用) AJAX原生AJAX1.1AJAX简介AJAX全程为Asynchronous JavaScript ...
React 开发报错整理 1、'yield' expression implicitly results in an 'any...
LLaMA 模型 大模型LLaMA详解LLaMa系列模型详解(原理介绍、代码解读)...
LlamaFactory可视化... LlamaFactory 前言LLaMA Factory 是一个用于微调大型语言模型的强大工具,特别...
Ajax从零到实战   💝💝💝欢迎来到我的博客,很高兴能够...
基于泰坦尼克号生还数据进行 S... 基于泰坦尼克号生还数据进行 Spark 分析在这篇博客中,我们将展示如何使用 Apac...
在亚马逊云科技AWS上利用Sa... 项目简介:接下来,小李哥将会每天介绍一个基于亚马逊云科技AWS云计算平台...