我使用postwait/node-amqp
(link)连接到我们组织中的各种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
});
});
});
};
答案 0 :(得分:1)
在amqp中,队列和交换是与连接无关的概念,它们不监听或广播,您不能连接到它们,而只能连接到代理。
RabbitMQ服务器当然接受网络连接,并且在传输的顶部the protocol defines是逻辑连接,该连接包括一个心跳信号,可以使用此库中的heartbeat
选项进行配置。
就像您说的那样,在启动时需要特别注意连接错误(包括超时),其余部分则可以依靠心跳,类似于“ ping”机制。如果连接中断并且设置了心跳参数,则库将简单地引发错误,因此您无需重新实现它。
您还应该查看postwait / node-ampq中的reconnect
设置,因为它可能会自动处理某些网络故障模式。