Azure Service Bus队列侦听器 - NodeJs

时间:2017-09-28 22:47:40

标签: node.js azure azureservicebus

我已经研究过但无法找到如何在Nodejs中创建Azure Service Bus队列侦听器。

到目前为止,我找到的唯一方法是使用Microsoft Azure SDK for Node.js通过消息向队列请求消息,这不符合成本效益。任何帮助将不胜感激。

sbService.receiveQueueMessage(queueName, { isPeekLock: true }, function(err, lockedMessage) {

    if (err) {
        if (err === 'No messages to receive') {
            console.log('No messages');
        } else {
            callback(err);
        }
    } else {
        callback(null, lockedMessage);
    }
});

2 个答案:

答案 0 :(得分:1)

对于您的方案,我建议使用Azure Functions,它提供服务总线队列触发器,使您可以通过侦听消息队列将代码连接到其他Azure服务或本地服务。有关详细信息,请参阅Service Bus bindings

enter image description here

答案 1 :(得分:0)

正如@ aaron-chen所说,最简单的解决方案是使用Azure Function和Servicebus触发器(没有额外的无聊代码......)

如果您无法使用Azure Function,则可以使用azure sdk for node.js,我发现这个sample形成了他们的回购来创建一个监听器:

var azure = require('azure-sb');

function checkForMessages(sbService, queueName, callback) {
    sbService.receiveQueueMessage(queueName, { isPeekLock: true }, function (err, lockedMessage) {
        if (err) {
            if (err == 'No messages to receive') {
                console.log('No messages');
            } else {
                callback(err);
            }
         } else {
             callback(null, lockedMessage);
         }
    });
}

function processMessage(sbService, err, lockedMsg) {
    if (err) {
        console.log('Error on Rx: ', err);
    } else {
        console.log('Rx: ', lockedMsg);
        sbService.deleteMessage(lockedMsg, function(err2) {
            if (err2) {
                console.log('Failed to delete message: ', err2);
            } else {
                console.log('Deleted message.');
            }
        })
    }
}

var idx = 0;
function sendMessages(sbService, queueName) {
    var msg = 'Message # ' + (++idx);
    sbService.sendQueueMessage(queueName, msg, function (err) {
        if (err) {
            console.log('Failed Tx: ', err);
        } else {
            console.log('Sent ' + msg);
        }
    });
}

var connStr = process.argv[2] || process.env.CONNECTION_STRING;
if (!connStr) throw new Error('Must provide connection string');
var queueName = 'sbqtest';

console.log('Connecting to ' + connStr + ' queue ' + queueName);
var sbService = azure.createServiceBusService(connStr);
sbService.createQueueIfNotExists(queueName, function (err) {
    if (err) {
        console.log('Failed to create queue: ', err);
    } else {
        setInterval(checkForMessages.bind(null, sbService, queueName, processMessage.bind(null, sbService)), 5000);
        setInterval(sendMessages.bind(null, sbService, queueName), 15000);
    }
});