是否有相当于" ping"对于RabbitMQ?如何诊断交换机或队列是否正在广播?

时间:2016-03-21 17:03:19

标签: node.js amqp

我使用postwait/node-amqplink)连接到我们组织中的各种RabbitMQ交换和队列。

由于我的项目已从开发阶段转移到生产阶段,我遇到了一些问题,即队列设置不正确或密码不正确等等。在后一种情况下,很明显,我会得到ECONNREFUSED错误。但在第一种情况下,我没有收到任何错误,只是连接超时。

给定像amqp://USER:PASS@messaging.abc.xyz.com这样的URI,如何判断一个名为" FooWorkItems.Work'的队列。接受聆听的联系?什么是最低限度的代码,相当于检查API是在监听还是服务器启动并在ping端口上监听?

代码:

if (this.amqpLib == null) {
    this.amqpLib = require('amqp');
  }
this.connection = this.amqpLib.createConnection({
    url: this.endpoint
  });

  this.connection.on('ready', (function(_this) {
    return function() {
      var evt, _fn, _fn1, _i, _j, _len, _len1, _ref, _ref1;
      _this.logger.info("" + _this.stepInfo + " connected to " + _this.endpoint + "; connecting to " + queueName + "  now.");
      if (_this.fullLogging) {
        _ref = ['connect', 'heartbeat', 'data'];
        _fn = function(evt) {
          return _this.connection.on(evt, function() {
            _this.logger.trace("" + _this.stepInfo + " AMQP event: " + evt);
            if (arguments != null) {
              return _this.logger.trace({
                args: arguments
              });
            }
          });
        };
        for (_i = 0, _len = _ref.length; _i < _len; _i++) {
          evt = _ref[_i];
          _fn(evt);
        }
        _ref1 = ['error', 'close', 'blocked', 'unblocked'];
        _fn1 = function(evt) {
          return _this.connection.on(evt, function() {
            if (evt !== 'close') {
              return _this.logger.error("" + _this.stepInfo + " AMQP event: " + evt);
            } else {
              return _this.logger.warn("" + _this.stepInfo + " AMQP event: " + evt);
            }
          });
        };
        for (_j = 0, _len1 = _ref1.length; _j < _len1; _j++) {
          evt = _ref1[_j];
          _fn1(evt);
        }
      }
      return _this.connection.queue(_this.queueName, {
        passive: true
      }, function(q) {
        logger.debug("" + stepInfo + " connected to queue " + queueName + ". Init complete.");
        return q.subscribe(function(message, headers, deliveryInfo, messageObject) {
          logger.trace("" + stepInfo + " recvd message");
          return logger.trace({
            headers: headers
          });
        });
      });
    };

1 个答案:

答案 0 :(得分:1)

在amqp中,队列和交换是与连接无关的概念,它们不监听或广播,您不能连接到它们,而只能连接到代理。

RabbitMQ服务器当然接受网络连接,并且在传输的顶部the protocol defines是逻辑连接,该连接包括一个心跳信号,可以使用此库中的heartbeat选项进行配置。

就像您说的那样,在启动时需要特别注意连接错误(包括超时),其余部分则可以依靠心跳,类似于“ ping”机制。如果连接中断并且设置了心跳参数,则库将简单地引发错误,因此您无需重新实现它。

您还应该查看postwait / node-ampq中的reconnect设置,因为它可能会自动处理某些网络故障模式。