ZeroMQ:多个远程(LAN)发布者

时间:2012-11-10 17:15:13

标签: python zeromq

我有一个基本的ZeroMQ场景,包括两个发布者和一个订阅者。这在本地计算机上运行良好,直到我决定将LAN中不同计算机中的所有进程分开。这就是我创建ZeroMQ套接字(简化的Python代码)的方法:

(在具有IP 192.168.1.52的计算机上运行的订阅者进程)

发布商代码(两个发布商都很常见):

context = zmq.Context()
self.pub_socket = context.socket(zmq.PUB)
self.pub_socket.connect("tcp://192.168.1.52:5556")

订阅者代码:

context = zmq.Context()
self.sub_socket = context.socket(zmq.SUB)
self.sub_socket.bind("tcp://192.168.1.52:5556")
self.sub_socket.setsockopt(zmq.SUBSCRIBE, "")

我已尝试输入tcp://127.0.0.1:5556作为订阅者的address:port绑定,但这没有任何区别。

4 个答案:

答案 0 :(得分:3)

我怀疑您的问题可能与您机器之间端口的开放性有关。某些操作系统有自己的软件防火墙,因此您可能需要检查是否需要打开它们。

首先,我会检查您是否可以在两台机器之间执行简单的req / rep之一:

# machine 1
import zmq
context = zmq.Context()
socket = context.socket(zmq.REP)
socket.bind("tcp://*:5556")
req = socket.recv()
socket.send(req) 

# machine 2
import zmq
context = zmq.Context()
socket = context.socket(zmq.REQ)
socket.connect("tcp://192.168.1.52:5556")
socket.send("FOO")
print socket.recv()

如果您遇到问题,那么您可能需要检查这些端口。

其次,您也可以尝试使用:socket.bind("tcp://*:5556")

绑定到所有接口

对于你的实际目标,如果你需要的只是一个多传感器/单接收器,你可以只使用PUSH / PULL而不是PUB / SUB

# one receiver
import zmq
context = zmq.Context()
socket = context.socket(zmq.PULL)
socket.bind("tcp://*:5556")

while True:
    print socket.recv()

# many senders
import zmq
context = zmq.Context()
socket = context.socket(zmq.PUSH)
socket.connect("tcp://192.168.1.52:5556")
socket.send("FOO")

答案 1 :(得分:1)

您是否在ZMQ公会中完成了“Missing Message Problem Solver”?

请注意,使用PUB / SUB模式时,会出现慢速木匠综合症,但总会丢失一些消息。如果我们在SUB中连接并在PUB中绑定,则可以消除该综合症;但是,当拥有多个发布者时,订阅者需要连接到所有发布者。

答案 2 :(得分:0)

感谢大家的建议。

防火墙确实被禁用,但最终找到了一台可以从两个发布商那里获得的PC。这似乎是与每台计算机上安装的ZMQ版本相关的问题。发送者有v.2.2,而接收者有2.1。这很奇怪,因为我认为zmq协议与版本无关。下次需要记住这一点。

再次感谢!

答案 3 :(得分:0)

协议应该在2.1和2.2之间工作,但它被3.1打破了。在3.2中,我们修复了旧版本的内容。