html读取消息队列,node怎么做消息队列?

本文介绍了如何利用Node.js和UDP协议创建一个简单消息队列。消息队列允许发送者和接收者无需直接交互,通过队列进行异步通信。在示例中,节点服务监听UDP端口5555,接收到消息后,根据消息ID将消息存储或转发。测试步骤包括启动服务并使用两个UDP测试工具进行消息发送和接收。
摘要由CSDN通过智能技术生成

消息队列(Message Queue)是一种应用间的通信方式,消息发送后可以立即返回,由消息系统来确保消息的可靠传递。消息发布者只管把消息发布到MQ中而不用管谁来取,消息使用者只管从MQ中取消息而不管是谁发布的。这样发布者和使用者都不用知道对方的存在。

417210f6f165d6b3fc93e4ff00c7e043.png

消息队列的使用场景异步处理

应用解耦

流量削峰

使用nodejs+UDP实现一个简单的消息队列const udpClient = require('dgram').createSocket('udp4');

var clients= {};

udpClient.on('message', (message, socket) => {

var repMsg="";

var msgObj= JSON.parse(message.toString());

if(msgObj["id"] != null) {

if(clients[msgObj["id"]] != null &&clients[msgObj["id"]].length> 0) {

repMsg = clients[msgObj["id"]].shift();

}

}

else {

var from =msgObj["from"];

var to =msgObj["to"];

var msg =msgObj["msg"];

if(clients[to] == null) {

clients[to] = new Array();

}

clients[to].push(message.toString());

repMsg = "1";

}

var buf = new Buffer(repMsg);

udpClient.send(buf, 0, buf.length, socket.port, socket.address);

});

udpClient.bind(5555);

测试步骤:

启动服务: node udpmq.js

打开两个UDP测试工具,如下图。左边是发送消息(json格式),客户端 “aa”发送给”bb”,

右图是接收消息,客户端”bb”发送自己的id给消息队列服务,服务查找“bb”的消息数组,并按FIFO的方式返回“bb”一条消息。

42eddfe03fa086bf32219b342a7de31b.pngUDP 是User Datagram Protocol的简称, 中文名是用户数据报协议,是OSI(Open System Interconnection,开放式系统互联) 参考模型中一种无连接的传输层协议,提供面向事务的简单不可靠信息传送服务,IETF RFC 768是UDP的正式规范。UDP在IP报文的协议号是17。

UDP 为应用程序提供了一种无需建立连接就可以发送封装的 IP 数据报的方法。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值