stomp+websocket 集群问题_WebSocket实现多人在线聊天室(分布式部署)

本文介绍了如何将WebSocket聊天室改造为分布式集群,以解决单点故障问题。通过使用Redis作为 Publish/Subscribe 中间件,实现服务器间的消息同步。详细讲述了用户在集群中发送和接收消息的流程,并提供了STOMP协议的简介,以及具体的功能实现步骤,包括添加Redis依赖、配置Redis、监听Redis频道、改造发送和接收消息的Controller与Service。
摘要由CSDN通过智能技术生成
04d8824a8e2cddcdbb6f4ad2e344ce83.png
c1ee6cd4a240b4ebdc32631ae7751d85.png

前言

书接上文(手把手教你使用WebSocket搭建多人在线聊天室),我们开始对我们的小小聊天室进行集群化改造。

本文内容摘要:

  • 为何要改造为分布式集群
  • 如何改造为分布式集群
  • 用户在聊天室集群如何发消息
  • 用户在聊天室集群如何接收消息
  • 补充知识点:STOMP 简介
  • 功能一:向聊天室集群中的全体用户发消息——Redis的订阅/发布
  • 功能二:集群集群用户上下线通知——Redis订阅发布
  • 功能三:集群用户信息维护——Redis集合
  • WebSocket集群还有哪些可能性

本文源码:(妈妈再也不用担心我无法复现文章代码啦)

https://github.com/qqxx6661/springboot-websocket-demo/releases/tag/%E9%9B%86%E7%BE%A4%E7%89%88

如果您觉得这个教程对您有用,请关注我的技术公众号:Rude3Knife,不定时更新技术点滴。

正文

WebSocket集群/分布式改造:实现多人在线聊天室

为何要改造为分布式集群

分布式就是为了解决单点故障问题,想象一下,如果一个服务器承载了1000个大佬同时聊天,服务器突然挂了,1000个大佬瞬间全部掉线,大概明天你就被大佬们吊起来打了。

当聊天室改为集群后,就算服务器A挂了,服务器B上聊天的大佬们还可以愉快的聊天,并且在前端还能通过代码,让连接A的大佬们快速重连至存活的服务器B,继续和大家愉快的聊天,岂不美哉!

总结一下:实现了分布式WebSocket后,我们可以将流量负载均衡到不同的服务器上并提供一种通信机制让各个服务器能进行消息同步(不然用户A连上服务器A,用户B脸上服务器B,它们发消息的时候对方都没法收到)。

如何改造为分布式集群

当我们要实现分布式的时候,我们则需要在各个机器上共享这些信息,所以我们需要一个Publish/Subscribe的中间件。我们现在使用Redis作为我们的解决方案。

1. 用户在聊天室集群如何发消息

假设我们的聊天室集群有服务器A和B,用户Alice连接在A上,Bob连接在B上、

Ali

好的,下面是一个简单的示例代码,演示了如何在Spring Boot应用程序中使用STOMPWebSocket实现简单的消息传递。 首先,需要添加以下依赖项: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-websocket</artifactId> </dependency> <dependency> <groupId>org.webjars</groupId> <artifactId>webjars-locator-core</artifactId> </dependency> <dependency> <groupId>org.webjars</groupId> <artifactId>sockjs-client</artifactId> <version>1.1.2</version> </dependency> <dependency> <groupId>org.webjars</groupId> <artifactId>stomp-websocket</artifactId> <version>2.3.3</version> </dependency> ``` 然后,在Spring Boot应用程序的主类上添加`@EnableWebSocketMessageBroker`注释,以启用WebSocket消息代理: ```java @SpringBootApplication @EnableWebSocketMessageBroker public class DemoApplication { public static void main(String[] args) { SpringApplication.run(DemoApplication.class, args); } } ``` 接下来,创建一个WebSocket配置类,用于配置STOMP消息代理: ```java @Configuration public class WebSocketConfig implements WebSocketMessageBrokerConfigurer { @Override public void configureMessageBroker(MessageBrokerRegistry config) { config.enableSimpleBroker("/topic"); config.setApplicationDestinationPrefixes("/app"); } @Override public void registerStompEndpoints(StompEndpointRegistry registry) { registry.addEndpoint("/chat").withSockJS(); } } ``` 这里配置了一个简单的消息代理,用于处理来自`/app`前缀的应用程序消息和来自`/topic`前缀的广播消息。同时,配置了一个STOMP端点,允许使用SockJS协议进行WebSocket通信。 接下来,在控制器类中添加以下代码,处理来自客户端的消息: ```java @Controller public class ChatController { @MessageMapping("/chat") @SendTo("/topic/messages") public ChatMessage sendMessage(ChatMessage message) { return new ChatMessage(message.getFrom(), message.getText()); } } ``` 这里定义了一个处理`/chat`端点的方法,当接收到客户端发送的消息时,会将消息转发到`/topic/messages`频道上。`ChatMessage`是一个简单的POJO类,用于表示聊天消息。 最后,在前端页面中添加以下代码,用于与WebSocket服务器建立连接和发送消息: ```javascript var stompClient = null; function connect() { var socket = new SockJS('/chat'); stompClient = Stomp.over(socket); stompClient.connect({}, function (frame) { console.log('Connected: ' + frame); stompClient.subscribe('/topic/messages', function (chatMessage) { showMessage(JSON.parse(chatMessage.body)); }); }); } function sendMessage() { var from = document.getElementById('from').value; var text = document.getElementById('text').value; stompClient.send("/app/chat", {}, JSON.stringify({'from': from, 'text': text})); } function showMessage(chatMessage) { var messageArea = document.getElementById('messageArea'); messageArea.innerHTML += chatMessage.from + ': ' + chatMessage.text + '\n'; } ``` 这里使用SockJS和STOMP.js客户端库来与WebSocket服务器建立连接和发送消息。`connect()`方法用于建立连接,`sendMessage()`方法用于发送消息,`showMessage()`方法用于显示接收到的消息。 以上就是一个简单的示例,演示了如何在Spring Boot应用程序中使用STOMPWebSocket实现简单的消息传递。希望能帮到你。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值