我已经设置了运行Mosca的节点js服务器。客户端能够连接到Mosca服务器并发布消息。我需要以消息的形式(订阅某个主题)向客户端发送确认。
以下代码在客户端发布消息后不断发送多条消息。我错过了什么吗?
var settings = {
port: 1882,
backend: ascoltatore
};
var message = {
topic: 'crofters',
payload: 'OK', // or a Buffer
qos: 2
};
var server = new mosca.Server(settings);
server.on('clientConnected', function(client) {
console.log('client connected', client.id);
});
// fired when a message is received
server.on('published', function(packet, client ) {
var packet_payload = packet.payload;
packet_payload = packet_payload.toString();
console.log('Published', packet_payload);
server.publish(message, function() {
console.log('done!');
});
});
server.on('ready', setup);
function setup() {
console.log('Mosca server is up and running');
}
答案 0 :(得分:2)
事件侦听器driver = ... # line from above
侦听每个发布事件,包括服务器的。
当您在该侦听器中使用server.on('published', function(packet, client){...}
时,它会触发另一个已发布的事件,该事件会立即被侦听器捕获。
它永远不会停止发布,因为它永远不会停止捕捉自己的事件。
答案 1 :(得分:0)
我一直面临类似的问题。如果您注意到,Mosca只有QoS 0和Qos 1
所以我认为代理尝试多次发送相同的消息“至少一次”,直到它收到客户端的一些确认。检查此document