首页 > 解决方案 > 未通过 Azure 服务总线队列接收消息

问题描述

我有一个 C# 程序将消息发送到 Azure 服务总线 Q(在 VM 上)。消息应该由 node.js 应用程序(在 Mac 上)接收。问题是接收。我看到的行为是:

我知道 C# 程序正确发送消息,因为我在程序确认“发送”后立即使用服务总线资源管理器进行检查。当前正在同步模式下完成发送。

Node.js 程序:(使用最新的 azure 库和节点 8.9.4 运行)

logger.info("Connecting to service bus");
const sbService = azure.createServiceBusService(connectionString);
if (sbService != null) {
 sbService.createQueueIfNotExists(queueName, function (err) {
   if (err) {
     logger.error("Cannot connect to "+queueName+" :: "+ util.inspect(err, { depth: null }));
   } else {
      logger.info("Connected to Q :: processing begins ");
      var intervalID = setInterval(timerElapsed, 5000);
   }
 });
}

function timerElapsed() {
  sbService.receiveQueueMessage(queueName, { isPeekLock: false }, function (err, lockedMessage) {
      if (err) {
          if (err !== 'No messages to receive') {
            logger.error("receiveQueueMessage error states: "+ util.inspect(err, { depth: 2 }));
          } else {
            console.log('.');
          }
       } else {
         logger.info("received Message: "+ util.inspect(lockedMessage, { depth: 2 }));
       }
  });
}

[编辑] - 有趣的是,我在这里使用了来自 MS Github 的示例github 示例,结果相似。

标签: node.jsazureazureservicebus

解决方案


< bangs head on table > 看看这篇帖子中的线索延迟使用python。罪魁祸首是默认开启的队列分区。关掉它,瞧……


推荐阅读