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

相关文章

java向微信服务号发送消息的完整步骤实例

《java向微信服务号发送消息的完整步骤实例》:本文主要介绍java向微信服务号发送消息的相关资料,包括申请测试号获取appID/appsecret、关注公众号获取openID、配置消息模板及代码... 目录步骤1. 申请测试系统2. 公众号账号信息3. 关注测试号二维码4. 消息模板接口5. Java测试

C++ RabbitMq消息队列组件详解

《C++RabbitMq消息队列组件详解》:本文主要介绍C++RabbitMq消息队列组件的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. RabbitMq介绍2. 安装RabbitMQ3. 安装 RabbitMQ 的 C++客户端库4. A

SpringCloud整合MQ实现消息总线服务方式

《SpringCloud整合MQ实现消息总线服务方式》:本文主要介绍SpringCloud整合MQ实现消息总线服务方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、背景介绍二、方案实践三、升级版总结一、背景介绍每当修改配置文件内容,如果需要客户端也同步更新,

Nginx使用Keepalived部署web集群(高可用高性能负载均衡)实战案例

《Nginx使用Keepalived部署web集群(高可用高性能负载均衡)实战案例》本文介绍Nginx+Keepalived实现Web集群高可用负载均衡的部署与测试,涵盖架构设计、环境配置、健康检查、... 目录前言一、架构设计二、环境准备三、案例部署配置 前端 Keepalived配置 前端 Nginx

Redis高可用-主从复制、哨兵模式与集群模式详解

《Redis高可用-主从复制、哨兵模式与集群模式详解》:本文主要介绍Redis高可用-主从复制、哨兵模式与集群模式的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝... 目录Redis高可用-主从复制、哨兵模式与集群模式概要一、主从复制(Master-Slave Repli

一文带你搞懂Redis Stream的6种消息处理模式

《一文带你搞懂RedisStream的6种消息处理模式》Redis5.0版本引入的Stream数据类型,为Redis生态带来了强大而灵活的消息队列功能,本文将为大家详细介绍RedisStream的6... 目录1. 简单消费模式(Simple Consumption)基本概念核心命令实现示例使用场景优缺点2

Redis消息队列实现异步秒杀功能

《Redis消息队列实现异步秒杀功能》在高并发场景下,为了提高秒杀业务的性能,可将部分工作交给Redis处理,并通过异步方式执行,Redis提供了多种数据结构来实现消息队列,总结三种,本文详细介绍Re... 目录1 Redis消息队列1.1 List 结构1.2 Pub/Sub 模式1.3 Stream 结

在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基础二、消息序列化三、事务支持机制四、错误处理与重试五、性能优