我需要实现ZMQ的一些扩展,其中' REQ
'套接字有一个名为“ .request()
”的额外方法
如果第一个参数 0 , .request( 0, ... )
只发送消息,此方法可以接收多个参数并且(这里我有问题),否则它必须等待10秒,如果在这段时间我没有回应或错误,我必须 .close()
套接字并再次打开它。
所以,问题是:我如何知道在我的ZMQ扩展中 客户端连接后才能重新连接 那里 我的新套接字?
(我也需要使用promises,这就是代码中出现“ Q.deffer()
”以及所有这些内容的原因
var zmq = require('./pzmq');
var rq = zmq.socket('req');
var counter=0;
function onSuccess(msg) {
console.log('Response: '+msg);
console.log(msg instanceof Array);
}
function onError(err) {
console.log('Error: '+err);
}
rq.connect('tcp://127.0.0.1:8888');
console.log(rq.indentity);
// The "Hello" string is sent every second
reply = rq.request(0, counter++,4);
reply.then(onSuccess,onError);
在这里,我有一个ZMQ的小扩展,名为 pzmq
:
var zmq = require('zmq');
var Q = require('bluebird');
// Save the original socket method, we need it
var socket = zmq.socket;
// Create and store the wrapper method
zmq.socket = function(kind) {
// it uses the original method anyways, to get a zmq socket
var so = socket.call(zmq, kind);
if (kind == 'req') {
// if a 'req' socket is requested, then we add the extra method 2
so.request = request;
}
return so;
};
function request() {
var d = Q.defer();
var that = this;
var onResponse = function () {
console.log(arguments instanceof Array);
d.resolve(Array.prototype.slice.call(arguments));
that.removeListener('error', onError);
};
var onError = function (e) {
d.reject(e);
that.removeListener('message', onResponse);
};
this.once('message', onResponse); // set up the handler for only one message
this.once('error', onError); // set up the handler for only one
var argumentos = Array.prototype.slice.call(arguments);
var tiempo = argumentos[0];
if (tiempo==0){
this.send(argumentos);
}else{
//HERE IS THE PROBLEM
}
return d.promise;
}
答案 0 :(得分:1)
ZeroMQ库允许您根据需要设置可扩展的消息传递框架。灵活性是最大化,你的设计和想象界限是主要限制。
如果你需要.close()
/重新打开一个ZMQ套接字,你的应用程序应该创建它自己的,状态完整的连接管理器,它既有意识又有意义。负责传输类设置,连接寻址,原型选择以及最后但并非最不重要的.connect()
/ .bind()
/ ev的正确时间。重新订阅阶段。
似乎听起来很复杂?是的,但是,没有“廉价捷径”。低级库方法&属性根本无法“猜测”您的外部世界规则和优先级,因此轮到您指定+ analyze + design + test / validate在应用程序层上作为强制性功能/行为。
ZMQ将帮助您执行“休息”。