是否有可能从即将关闭的ZMQ套接字获取数据?

时间:2014-11-01 19:23:42

标签: javascript sockets zeromq

我需要实现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;
}

1 个答案:

答案 0 :(得分:1)

简短:没有。

长:是的。

ZeroMQ库允许您根据需要设置可扩展的消息传递框架。灵活性是最大化,你的设计和想象界限是主要限制。

如果你需要.close() /重新打开一个ZMQ套接字,你的应用程序应该创建它自己的,状态完整的连接管理器,它既有意识又有意义。负责传输类设置,连接寻址,原型选择以及最后但并非最不重要的.connect() / .bind() / ev的正确时间。重新订阅阶段。

似乎听起来很复杂?是的,但是,没有“廉价捷径”。低级库方法&属性根本无法“猜测”您的外部世界规则和优先级,因此轮到您指定+ analyze + design + test / validate在应用程序层上作为强制性功能/行为。

ZMQ将帮助您执行“休息”。