Spring Cloud Gateway整合基于STOMP协议的WebSocket实战及遇到问题解决

embedded/2024/9/19 0:50:02/ 标签: websocket, spring cloud, gateway

本实例介绍了Spring Cloud Gateway整合基于STOMP协议的WebSocket的实现。开发了聊天功能,和用户在线状态。解决了协议gateway整合websocket出现的问题

技术点

  • Spring Cloud Gateway
  • Nacos
  • WebSocket
  • STOMP

WebSocket与STOMP协议详解

1. WebSocket

WebSocket 是一种通信协议,提供了在客户端和服务器之间建立全双工通信的功能。这意味着客户端和服务器可以在任意时间相互发送数据,而不必遵循请求-响应的传统模式(如HTTP)。

特点:
  • 双向通信:与传统的HTTP不同,WebSocket允许服务器主动向客户端推送数据,而不必等待客户端请求。

  • 持久连接:WebSocket连接一旦建立,可以一直保持连接,直到任意一方关闭它。这减少了频繁建立连接的开销。

  • 低延迟:由于WebSocket消除了HTTP请求的头部开销和连接延迟,因此它适合于对延迟敏感的应用,如在线游戏、股票交易和聊天应用。

工作流程:
  1. 连接建立:客户端通过HTTP的升级机制(Upgrade header)请求建立WebSocket连接。

  2. 数据传输:一旦连接建立,客户端和服务器可以通过这个连接双向传输数据,使用一种轻量级的帧格式。

  3. 连接关闭:任意一方可以随时关闭连接,通知对方连接已关闭。

使用场景:
  • 实时聊天应用

  • 实时数据流(如股票行情、体育比赛更新)

  • 在线多人游戏

  • 实时协作工具(如Google Docs)

2. STOMP

STOMP(Simple Text Oriented Messaging Protocol) 是一种简单的文本协议,用于在客户端和消息代理(例如,RabbitMQ、ActiveMQ)之间交换消息。它是应用层的协议,常用于消息传递系统,提供了一种基于消息的通信方式。

特点:
  • 简单易用:STOMP使用类似于HTTP的文本格式,非常容易理解和实现。

  • 基于订阅/发布模型:STOMP支持基于主题(topic)的订阅/发布模型,这使得消息可以广播给多个客户端。

  • 支持消息队列:STOMP支持将消息发送到队列,多个消费者可以从同一个队列中读取消息,确保负载均衡。

常用命令:
  • CONNECT:客户端请求连接到STOMP服务器。

  • SEND:客户端发送一条消息到指定的目的地(如某个队列或主题)。

  • SUBSCRIBE:客户端订阅某个目的地,以接收该目的地的所有消息。

  • UNSUBSCRIBE:取消订阅。

  • DISCONNECT:断开与STOMP服务器的连接。

STOMP和WebSocket的结合:

虽然WebSocket本身是一个很好的低延迟双向通信工具,但它只提供了一种基础的传输方式,没有定义消息的格式或通信模式。STOMP可以在WebSocket之上运行,提供了消息格式、路由、确认等高级功能。

例如,在一个实时聊天应用中,WebSocket用于底层的双向通信,而STOMP则负责处理消息的路由和格式化:

  • 客户端通过WebSocket连接到服务器,并通过STOMP发送或订阅消息。

  • 服务器使用STOMP协议将消息广播给所有订阅了相应主题的客户端。

WebSocket服务端

依赖

<!-- WebSocket依赖 -->
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-websocket</artifactId>
</dependency>
<!-- nacos依赖 -->
<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
<dependency><groupId>com.alibaba.nacos</groupId><artifactId>nacos-client</artifactId>
</dependency>
<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>

枚举类

package com.inspur.message.constant;import lombok.AccessLevel;
import lombok.AllArgsConstructor;@AllArgsConstructor(access = AccessLevel.PRIVATE)
public enum MessageTypeEnum {TEXT("文本"),IMAGE("图片"),VOICE("语音"),FILE("文件"),EMOJI("表情"),SYSTEM_NOTIFICATION("系统通知"),LOCATION("位置"),LINK("链接"),RECALL("撤回"),MENTION("@提及"),SYSTEM_MESSAGE("系统提示"),VIDEO("视频"),RED_PACKET("红包"),VOTE("投票"),FRIEND_SHARE("好友分享");// 其他可能的消息类型...private String description;public String getDescription() {return description;}public static boolean isFileMessageType(MessageTypeEnum messageType) {return messageType == IMAGE || messageType == VOICE || messageType == FILE || messageType == VIDEO;}
}

WebSocket配置类

package com.inspur.message.config;import org.springframework.context.annotation.Configuration;
import org.springframework.messaging.simp.config.MessageBrokerRegistry;
import org.springframework.web.socket.config.annotation.EnableWebSocketMessageBroker;
import org.springframework.web.socket.config.annotation.StompEndpointRegistry;
import org.springframework.web.socket.config.annotation.WebSocketMessageBrokerConfigurer;@Configuration
@EnableWebSocketMessageBroker//注解开启STOMP协议来传输基于代理的信息,实现实时双向通信和消息传递
public class WebSocketConfig implements WebSocketMessageBrokerConfigurer {/*** 客户端在订阅或发布消息到目的地路径前,要连接到该端点** @param registry*/@Overridepublic void registerStompEndpoints(StompEndpointRegistry registry) {registry.addEndpoint("/ws").setAllowedOrigins("*").withSockJS();// 启用 SockJS (浏览器不支持WebSocket,SockJS 将会提供兼容性支持)}/*** 配置消息代理** @param register*/@Overridepublic void configureMessageBroker(MessageBrokerRegistry register) {/*** 放开的前缀路由,客户端才能接收对应路由开头的信息

http://www.ppmy.cn/embedded/108214.html

相关文章

UDP报文结构

UDP特点 无连接 , 不可靠传输 , 面向数据报 , 全双工 无连接: 知道对端的 IP 和端口号就直接进行传输,不需要建立连接.不可靠传输:没有确认机制,没有重传机制;如果因为网络故障导致该段无法发送对方,UDP协议层也不会给应用层返回任何错误信息.面向数据报:不能灵活的控制读写数…

MySQL的事务认识

什么是事务&#xff1f; 事务&#xff0c;就是将一组SQL语句放在同一批次内去执行&#xff0c;如果一个SQL语句出错&#xff0c;则该批次内 的所有SQL都将被取消执行。 事务的ACID原则 &#xff08;四大原则&#xff09; 原子性&#xff1a;意味着数据库中的事务执行是作为原…

javascript网页设计案例 插画样式登录页面

前言 JavaScript 是 Web 的编程语言。所有现代的 HTML 页面都可以使用 JavaScript。JavaScript 非常容易学。JavaScript 控制了网页的行为。 使用HTML、CSS和JavaScript进行网页设计是一个常见的任务。以下是一个简单的JavaScript和HTML结合的网页设计案例&#xff0c;用于登…

企业如何组建安全稳定的跨国通信网络?

组建一个安全稳定的跨国通信网络对于现代企业来说至关重要&#xff0c;尤其是当企业在全球范围内运营时。以下是一些关键步骤和考虑因素&#xff1a; 需求分析&#xff1a; 确定企业的具体通信需求&#xff0c;包括带宽要求、延迟敏感度、数据类型&#xff08;如语音、视频、文…

你真的直接知道TCP协议吗?滑动窗口是什么?有什么重传机制?拥塞控制又是什么?一篇文章带你吃透TCP协议

目录 1.TCP协议段格式 ​编辑 2.可靠性 2.1 确认应答(ACK) 2.2 流量控制 2.3 报文类型 2.3.1 URG 2.3.2 PSH 2.3.3 RST 2.3.4 FIN 2.3.5 ACK 2.3.6 SYN 2.4 超时重传 2.5 连接管理 2.6 拥塞控制 3. 提高性能 3.1 捎带应答 3.2滑动窗口 3.2.1 滑动窗口在哪里 …

postgres数据库中如何看查询是否走索引,以及在什么情况下走索引

在 PostgreSQL 中,可以通过 EXPLAIN 或 EXPLAIN ANALYZE 查看查询计划,以判断查询是否使用了索引。除此之外,了解索引的使用条件对于优化查询性能也很重要。 1. 如何查看查询是否使用索引 使用 EXPLAIN 查看查询计划 EXPLAIN 显示 PostgreSQL 如何执行查询,包括是否使用索…

2024数学建模国赛高教社杯C题:农作物的种植策略 思路代码文章助攻手把手保姆级

发布于18:25有问题后续会修正!! 背景信息 问题分析基于你提供的资料——2024年全国大学生数学建模竞赛C题&#xff0c;其核心内容为优化一个乡村的农作物种植策略。 背景分析 该乡村位于华北山区&#xff0c;气候较冷&#xff0c;土地资源有限&#xff0c;存在四种地块类型&a…

备份还原 本地所有的Docker 镜像并且在另一台机器上还原

备份命令 并且显示进度 backup_docker_images.sh sudo yum install jq chmod x backup_docker_images.shsudo ./backup_docker_images.sh#!/bin/bash# 指定备份目录 backup_dir"/app/dockerImageBackup/Images"# 创建备份目录&#xff0c;如果不存在的话 mkdir -p …

Elasticsearch文档值

在Elasticsearch中&#xff0c;文档值&#xff08;Doc Values&#xff09;是用于高效存储和检索数据的一种数据结构&#xff0c;特别是在处理聚合、排序和过滤操作时。文档值是Elasticsearch为每个字段生成的预先计算的格式化数据&#xff0c;目的是改善性能和降低内存使用。 …

【SpringBoot】电脑商城-12-订单功能

创建订单 1 订单-创建数据表 1.使用use命令先选中store数据库。 USE store;2.在store数据库中创建t_order和t_order_item数据表。 CREATE TABLE t_order (oid INT AUTO_INCREMENT COMMENT 订单id,uid INT NOT NULL COMMENT 用户id,recv_name VARCHAR(20) NOT NULL COMMENT …

小阿轩yx-云原生存储Rook部署Ceph

小阿轩yx-云原生存储Rook部署Ceph 前言 Rook 一款云原生存储编排服务工具由云原生计算基金会&#xff08;CNCF&#xff09;孵化&#xff0c;且于2020年10月正式进入毕业阶段。并不直接提供数据存储方案&#xff0c;而是集成了各种存储解决方案&#xff0c;并通过一种自管理、…

【云原生之kubernetes实战】k8s环境中部署Nginx服务

【云原生之kubernetes实战】k8s环境中部署Nginx服务 一、Nginx介绍1.1 Nginx简介1.2 Nginx特点1.3 Nginx使用场景二、本次实践介绍2.1 本次实践简介2.2 本次环境规划三、检查k8s环境3.1 检查工作节点状态3.2 检查系统pod状态四、部署storageclass(可选)4.1 配置NFS服务器4.2 …

橘子学ES实战操作之管道类型Ingest pipelines的基本使用

简介 我们在使用ES的时候&#xff0c;经常的用法就是把其他数据源比如Mysql的数据灌到ES中。 借用ES的一些功能来提供数据的全文检索以及聚合分析之类的功能。 在这个灌数据的过程中&#xff0c;我们经常会对数据做一些治理&#xff0c;类似ETL的能力。然后把治理后的数据写入…

数学建模_缺失值处理_拉格朗日、牛顿插值(全)

- 缺失值处理 1. 识别缺失值 在处理缺失值之前&#xff0c;首先需要识别数据中的缺失值。 1.1 使用 isna() 和 isnull() Pandas 提供了 isna() 和 isnull() 方法来检测缺失值&#xff0c;二者功能相同。 import pandas as pddf pd.DataFrame({A: [1, 2, None, 4],B: [None, 2,…

Java内存马系列 | SpringMVC内存马 - 上 | SpringMVC代码分析

文章目录 Java内存马\_SpringMVC代码分析新建一个SpingMVC项目新建项目或者模块编写一个简单的Spring Controller编写一个Spring Interceptor Spring MVC介绍Spring MVC的大致处理流程Spring MVC九大组件 SpringMVC源码分析九大组件的初始化源码分析url和controller的关系建立S…

JavaScript 知识点(从基础到进阶)

&#x1f30f;个人博客主页&#xff1a;心.c ​ 前言&#xff1a;JavaScript已经学完了&#xff0c;和大家分享一下我的笔记&#xff0c;希望大家可以有所收获&#xff0c;花不多说&#xff0c;开干&#xff01;&#xff01;&#xff01; &#x1f525;&#x1f525;&#x1f5…

苏州科技大学商学院:加强生态保护,推动绿色发展

原标题&#xff1a;苏州科技大学商学院&#xff1a;加强生态保护&#xff0c;推动绿色发展&#xff0c;在美丽中国建设中贡献青春力量 建设美丽中国是全面建设社会主义现代化国家的重要目标&#xff0c;也是激励全国人民为实现中华民族伟大复兴中国梦而共同奋斗的伟大旗帜。中…

Node.js发票查验接口示例、识别查验接口参数返回

财务、审计等经常与发票打交道的人员常常会遇到虚假发票、错票、重复报销等一系列问题。对于会计审计、代理记账、电子商务等发票查验量多的企业来说&#xff0c;成千上万张发票如果仅依赖于人工来进行核验&#xff0c;速度慢效率低&#xff0c;准确率也没保障&#xff0c;因此…

验证linux gpu是否可用

通过torch验证 import torchprint(torch.__version__) # 查看torch当前版本号 print(torch.version.cuda) # 编译当前版本的torch使用的cuda版本号 print(torch.cuda.is_available()) # 查看当前cuda是否可用于当前版本的Torch&#xff0c;如果输出True&#xff0c;则表示可…

【机器学习】朴素贝叶斯方法的概率图表示以及贝叶斯统计中的共轭先验方法

引言 朴素贝叶斯方法是一种基于贝叶斯定理的简单概率模型&#xff0c;它假设特征之间相互独立。 文章目录 引言一、朴素贝叶斯方法的概率图表示1.1 节点表示1.2 边表示1.3 无其他连接1.4 总结 二、朴素贝叶斯的应用场景2.1 文本分类2.2 推荐系统2.3 医疗诊断2.4 欺诈检测2.5 情…