Node.js和zmq

时间:2013-06-11 15:56:16

标签: javascript node.js zeromq

我对带有node和zmq的基本pubsub应用程序有一个奇怪的问题:

客户端正在向代理发布字符串,问题是代理只接收第一行。在网络级别我注意到只发送了第一条消息,然后对.send()函数的下一次调用没有效果(没有发送数据包)所以我认为问题出在客户端/发布者中。 我使用官方指南中提供的示例代码,它完美地工作,我的代码的唯一区别是我使用原型来拥有可重用的结构。 (我没有粘贴订阅者的代码,因为它不相关并且还带了一些其他不相关的东西)

客户/出版商的相关部分:

Publisher = function(zmq, pport) {
    this.logread = spawn('tail', ['-n0', '-f', '/var/log/auth.log']);
    this.publisher = zmq.socket('req');
    this.pport = pport;
};

Publisher.prototype.start = function() {
    var self = this;
    this.publisher.connect('tcp://127.0.0.1:' + this.pport);
    this.logread.stdout.on('data', function(data){
        self.publisher.send(data.toString());
        console.log(data.toString());
    });
};

经纪人的相关部分:

Broker = function(zmq, bpport, bsport) {
    this.server = zmq.socket('rep');
    this.bpport = bpport;
    this.bsport = bsport;
};

Broker.prototype.start = function() {
    this.server.on('message', function(request) {
        console.log(request.toString());
    });

    this.server.bind('tcp://127.0.0.1:' + this.bsport, function(err) {
        if (err)
            console.log(err);
    });

};

2 个答案:

答案 0 :(得分:1)

您正在讨论发布订阅模式,但在您的代码中,您创建了一个req套接字,并在代理中创建了一个rep套接字,用于请求 - 回复模式。请求 - 回复模式严格需要先发送,而不是接收,请参阅api docs文档,或阅读guide

中的更多内容

我想你应该在客户端使用pub套接字,在另一端使用sub套接字,但不知道你想要实现什么,也许不同的模式适合你的需求更好。

答案 1 :(得分:0)

所以我会回答我的问题: 服务器必须向客户端发送回复,直到那时客户端不会发送更多消息

server.send('OK');

我也认为有不同的方法来实现这个