STOMP 消息高可用推送

2023-11-29 05:48
文章标签 推送 消息 可用 stomp

本文主要是介绍STOMP 消息高可用推送,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、背景

前端在部分消息需要实时推送,如果需要推送的终端比较多并且消息的准确性要求比较高,因此需要采用高可用

2、高可用方案

2.1 Websocket

Websocket+gateway网关

缺点:

  1. 实现起来有一定困难
  2. 基于gateway网关,对网关会造成一定性能压力

2.2 Stomp

        借用消息中间件实现高可用,如RabbitMQ、RocketMQ都支持Stomp协议。后端直接搭建消息高可用集群,前端通过Stomp协议直接连接消息中间件,进行消息订阅和发布。应用服务同样进行消息的订阅或发布。

2.2.1 STOMP协议

STOMP即Simple (or Streaming) Text Orientated Messaging Protocol,简单(流)文本定向消息协议,它提供了一个可互操作的连接格式,允许STOMP客户端与任意STOMP消息代理(Broker)进行交互。STOMP协议由于设计简单,易于开发客户端,因此在多种语言和多种平台上得到广泛地应用。

2.2.2 前端调用示例

<!DOCTYPE html>
<html>
<head><meta charset="UTF-8" /><title>Websocket</title><noscript><h2 style="color:#ff0000">貌似你的浏览器不支持websocket</h2></noscript><script src="js/sockjs.min.js"></script><script src="js/stomp.min.js"></script><script src="js/jquery-3.4.1.min.js"></script><script type="text/javascript">var host="ws://192.168.56.101:15674/ws";function login() {host=$("#host").val();connect();}var stompClient = null;function setConnected(connected) {$('#disconnect').attr("disabled",false);$('#response').html();}function connect() {//地址+端点路径,构建websocket链接地址var headers = {"login": "admin","passcode": "admin",//虚拟主机,默认“/”"host": "/"};var username = document.getElementById("username").value;stompClient = Stomp.client(host);stompClient.connect(headers, function(frame) {setConnected(true);console.log('Connected:' + frame);showResponse('Connected');$("#message-container").show();$('#loginButton').attr("disabled",true);stompClient.subscribe('/queue/' + username, function(response) {showResponse(response.body);});},function(frame) {console.log('Connect fail:' + frame);showResponse('Connect fail:' + frame);});}function disconnect() {if (stompClient != null) {stompClient.disconnect();}setConnected(false);console.log("Disconnected");showResponse("Disconnected");}function send() {var username = $('#username').val();var message = $('#message').val();//发送消息的路径stompClient.send('/queue/' + username, {"content-type":"text/plain"}, JSON.stringify({username:username,message:message}));}function showResponse(message) {var response = $('#response');var html="<div><b>"+dateFormat("YYYY-mm-dd HH:MM:SS",new Date())+"</b>  :"+message+"</div>"response.append(html);}function dateFormat(fmt, date){let ret;const opt = {"Y+": date.getFullYear().toString(),        // 年"m+": (date.getMonth() + 1).toString(),     // 月"d+": date.getDate().toString(),            // 日"H+": date.getHours().toString(),           // 时"M+": date.getMinutes().toString(),         // 分"S+": date.getSeconds().toString()          // 秒// 有其他格式化字符需求可以继续添加,必须转化成字符串};for (let k in opt) {ret = new RegExp("(" + k + ")").exec(fmt);if (ret) {fmt = fmt.replace(ret[1], (ret[1].length == 1) ? (opt[k]) : (opt[k].padStart(ret[1].length, "0")))};};return fmt;}
</script>
</head>
<body><div style=""><div><span>地址</span><input type="text"  placeholder="服务器地址" id="host" style="width: 200px" value="ws://192.168.56.101:15674/ws"/><br/><span>用户</span><input type="text"  placeholder="请输入用户名" id="username" style="width: 200px" value="jack"/></div><button type="button" id="loginButton" onclick="login()">登录</button><button type="button" id="disconnect" onclick="disconnect();" disabled>断开连接</button></div><div style=""><div id="message-container" style="display:none"><span>消息</span><input type="text" id="message" style="width: 200px" value="hello,world!"/><button type="button" id="send" onclick="send()">发送</button></div></div><div style="height: 400px;border: 1px solid black;padding:10px;width:300px;overflow-y:auto;"><div id="response"></div></div></body>
</html>

这篇关于STOMP 消息高可用推送的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/431695

相关文章

在Android平台上实现消息推送功能

《在Android平台上实现消息推送功能》随着移动互联网应用的飞速发展,消息推送已成为移动应用中不可或缺的功能,在Android平台上,实现消息推送涉及到服务端的消息发送、客户端的消息接收、通知渠道(... 目录一、项目概述二、相关知识介绍2.1 消息推送的基本原理2.2 Firebase Cloud Me

MySQL双主搭建+keepalived高可用的实现

《MySQL双主搭建+keepalived高可用的实现》本文主要介绍了MySQL双主搭建+keepalived高可用的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、测试环境准备二、主从搭建1.创建复制用户2.创建复制关系3.开启复制,确认复制是否成功4.同

SpringKafka消息发布之KafkaTemplate与事务支持功能

《SpringKafka消息发布之KafkaTemplate与事务支持功能》通过本文介绍的基本用法、序列化选项、事务支持、错误处理和性能优化技术,开发者可以构建高效可靠的Kafka消息发布系统,事务支... 目录引言一、KafkaTemplate基础二、消息序列化三、事务支持机制四、错误处理与重试五、性能优

SpringIntegration消息路由之Router的条件路由与过滤功能

《SpringIntegration消息路由之Router的条件路由与过滤功能》本文详细介绍了Router的基础概念、条件路由实现、基于消息头的路由、动态路由与路由表、消息过滤与选择性路由以及错误处理... 目录引言一、Router基础概念二、条件路由实现三、基于消息头的路由四、动态路由与路由表五、消息过滤

Spring Boot整合消息队列RabbitMQ的实现示例

《SpringBoot整合消息队列RabbitMQ的实现示例》本文主要介绍了SpringBoot整合消息队列RabbitMQ的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的... 目录RabbitMQ 简介与安装1. RabbitMQ 简介2. RabbitMQ 安装Spring

springboot rocketmq配置生产者和消息者的步骤

《springbootrocketmq配置生产者和消息者的步骤》本文介绍了如何在SpringBoot中集成RocketMQ,包括添加依赖、配置application.yml、创建生产者和消费者,并展... 目录1. 添加依赖2. 配置application.yml3. 创建生产者4. 创建消费者5. 使用在

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque

解读Redis秒杀优化方案(阻塞队列+基于Stream流的消息队列)

《解读Redis秒杀优化方案(阻塞队列+基于Stream流的消息队列)》该文章介绍了使用Redis的阻塞队列和Stream流的消息队列来优化秒杀系统的方案,通过将秒杀流程拆分为两条流水线,使用Redi... 目录Redis秒杀优化方案(阻塞队列+Stream流的消息队列)什么是消息队列?消费者组的工作方式每

使用C/C++调用libcurl调试消息的方式

《使用C/C++调用libcurl调试消息的方式》在使用C/C++调用libcurl进行HTTP请求时,有时我们需要查看请求的/应答消息的内容(包括请求头和请求体)以方便调试,libcurl提供了多种... 目录1. libcurl 调试工具简介2. 输出请求消息使用 CURLOPT_VERBOSE使用 C

Java中Springboot集成Kafka实现消息发送和接收功能

《Java中Springboot集成Kafka实现消息发送和接收功能》Kafka是一个高吞吐量的分布式发布-订阅消息系统,主要用于处理大规模数据流,它由生产者、消费者、主题、分区和代理等组件构成,Ka... 目录一、Kafka 简介二、Kafka 功能三、POM依赖四、配置文件五、生产者六、消费者一、Kaf