【发布时间】:2015-08-03 01:06:56
【问题描述】:
原来的问题在这里:https://github.com/JustinTulloss/zeromq.node/issues/444
你好,
如果我从 Node.js 订阅 Python 中的发布者,订阅者将无法接收消息。另一方面,Node-publisher 可以同时发送 python-subscriber 和 node-subscriber,python-publisher 可以发送 python 订阅者。
节点订阅者:
// Generated by LiveScript 1.4.0
(function(){
var zmq, sock;
zmq = require('zmq');
sock = zmq.socket('sub');
sock.connect('tcp://127.0.0.1:3000');
sock.subscribe('');
console.log('Subscriber connected to port 3000');
sock.on('message', function(message){
return console.log('Received a message related to: ', 'containing message: ', message.toString());
});
}).call(this);
节点发布者:
// Generated by LiveScript 1.4.0
(function(){
var zmq, sock;
zmq = require('zmq');
sock = zmq.socket('pub');
sock.bindSync('tcp://127.0.0.1:3000');
console.log('Publisher bound to port 3000');
setInterval(function(){
console.log('Sending a multipart message envelope');
return sock.send('TestMessage(node)!');
}, 1500);
}).call(this);
Python 发布者
import zmq
import time
context = zmq.Context()
publisher = context.socket(zmq.PUB)
publisher.bind("tcp://127.0.0.1:3000")
while True:
time.sleep(1)
publisher.send("TestMessage")
print "Sent"
Python 订阅者:
import zmq
context = zmq.Context()
socket = context.socket(zmq.SUB)
socket.setsockopt(zmq.SUBSCRIBE, "")
socket.connect("tcp://127.0.0.1:3000")
while True:
string = socket.recv()
print string
【问题讨论】:
标签: python node.js zeromq publish-subscribe