zeromq epgm pub / sub无法正常工作

时间:2013-03-23 09:04:53

标签: node.js zeromq multicast pgm-protocol

我正在使用node.js示例。我在我的ubuntu 12.10机器上安装了openpgm和zeromq 3.2。这是代码:

var zmq = require('zmq')
  , port = 'epgm://eth0;239.192.1.1:5555';

  var socket = zmq.socket('pub');

  socket.identity = 'publisher' + process.pid;

  var stocks = ['AAPL', 'GOOG', 'YHOO', 'MSFT', 'INTC'];

  socket.bind(port, function(err) {
    if (err) throw err;
    console.log('bound!');

    setInterval(function() {
      var symbol = stocks[Math.floor(Math.random()*stocks.length)]
        , value = Math.random()*1000;

      console.log(socket.identity + ': sent ' + symbol + ' ' + value);
      socket.send(symbol + ' ' + value);
    }, 1000);
  });

和另一个应用:

  

var zmq = require('zmq'),port ='epgm:// eth0; 239.192.1.1:5555';

     

var socket = zmq.socket('sub');

     

socket.identity ='subscriber'+ process.pid;

     

socket.connect(端口);

     

socket.subscribe( 'AAPL'); socket.subscribe( '歌');

     

的console.log( '连接!');

     

socket.on('message',function(data){       console.log(socket.identity +':received data'+ data.toString()); });

我不确定我是否使用了正确的多播寻址。我已经在同一台机器上和这个网络中的另一台机器上一起试过这些应用程序。我很确定我没有考虑过那部分,但我似乎无法在任何地方找到任何好的解释。但无论如何,我希望这可以在同一台机器上工作。有什么想法吗?

PS:忘了解释究竟发生了什么:基本上推送程序只是推送所有消息而没有任何错误,并且pull程序启动但没有收到任何消息。

2 个答案:

答案 0 :(得分:2)

epgm和pgm仅适用于PUB / SUB。

答案 1 :(得分:2)

不确定这是否有帮助,但我也一直在节点中尝试zmq并做了一些观察:

我正在使用四台机器运行: 1:OS X 10.8.3 2:VM中的Ubuntu 12.10(桥接) 3:Ubuntu 12.04独立机器
4:Ubuntu 12.04独立机器

当我在所有机器上启动相同的测试服务器时(与上面的代码差别不大) 机器1:查看机器3和4的更新 机器2:查看1,2,3和4的更新 机器3:从1,3,4看到更新 机器4:看到来自1,3,4的更新

所以似乎OS X会阻止广播。虚拟机中的Ubuntu 12.10正在吸引所有人,但发送时遇到问题(可能与在VM中运行有关?)而其他机器正在自行开发。

我的服务器/客户端:

os = require 'os'
zmq = require 'zmq'

client = zmq.socket "sub"
server = zmq.socket "pub"

client.connect "epgm://224.0.0.1:5555", (error) ->
    if error?
        console.log "client error:", error

client.subscribe ""
client.on "message", (buffer) ->
    console.log "received ping:", buffer.toString!

server.bind "epgm://224.0.0.1:5555", (error) ->
    if error?
        console.log "server error:", error
    setInterval ( -> 
        server.send "#{os.hostname!}" 
    ), 1000

process.on "SIGINIT", ->
    client.close!
    server.close!
    process.exit!