用于环形拓扑的 ZeroMQ - 如何配置套接字?
ZeroMQ for ring topology - how to configure sockets?
我正在尝试使用 ZeroMQ 连接环形拓扑中的多个主机。但是我尝试了很长时间,希望现在能得到一些帮助。
基本上,我有一个客户端 C,它通过多个主机 H1...Hn 向自身 S 发送消息 M。是环形通讯。
C -> H2 -> H1 -> S # where C and S are on the same host.
IP addresses:
C, S: 192.168.100.165
H2: 192.168.100.102
H1: 192.168.100.101
H1 和 H2 需要对消息进行处理并将其转发给下一个主机。
我尝试遵循 official ZeroMQ doc 的 extended request-reply pattern
示例。
这是我的客户 C:
main_context = zmq.Context()
client_socket = main_context.socket(zmq.REQ)
client_socket.connect("tcp://192.168.100.102:5556")
while 1:
client_socket.send("hello!")
ug_response = client_socket.recv()
time.sleep(3)
我的服务器S来了(在同一台主机上。即使是同一个程序,只是另一个线程):
ug_server_context = zmq.Context()
server_socket = ug_server_context.socket(zmq.REP)
server_socket.bind("tcp://*:5558")
while 1:
updated_ug_message = server_socket.recv()
server_socket.send("ug received.")
这是我的 "brokers" 使用 ROUTER 和 DEALER 的 H1 和 H2:
context = zmq.Context()
# Prepare broker sockets
frontend = context.socket(zmq.ROUTER)
backend = context.socket(zmq.DEALER)
frontend.bind("tcp://*:5556") # for H1: 5557
backend.bind("tcp://*:5557") # for H1: 5558
# Initialize broker poll set
poller = zmq.Poller()
poller.register(frontend, zmq.POLLIN)
poller.register(backend, zmq.POLLIN)
# Switch messages between sockets
while 1:
socks = dict(poller.poll())
if socks.get(frontend) == zmq.POLLIN:
message = frontend.recv_multipart()
backend.send_multipart(message)
if socks.get(backend) == zmq.POLLIN:
message = backend.recv_multipart()
frontend.send_multipart(message)
问题是,它不起作用,我的问题是:
1. H2 如何知道它必须向 H1 发送消息?
2。我的方向对吗?
好的,与此同时我自己弄明白了。我不得不改变:
backend.bind("tcp://*:5557")
至:
backend.connect("tcp://192.168.100.101:5557")
现在我的通讯戒指很好用了。
我正在尝试使用 ZeroMQ 连接环形拓扑中的多个主机。但是我尝试了很长时间,希望现在能得到一些帮助。
基本上,我有一个客户端 C,它通过多个主机 H1...Hn 向自身 S 发送消息 M。是环形通讯。
C -> H2 -> H1 -> S # where C and S are on the same host.
IP addresses:
C, S: 192.168.100.165
H2: 192.168.100.102
H1: 192.168.100.101
H1 和 H2 需要对消息进行处理并将其转发给下一个主机。
我尝试遵循 official ZeroMQ doc 的 extended request-reply pattern
示例。
这是我的客户 C:
main_context = zmq.Context()
client_socket = main_context.socket(zmq.REQ)
client_socket.connect("tcp://192.168.100.102:5556")
while 1:
client_socket.send("hello!")
ug_response = client_socket.recv()
time.sleep(3)
我的服务器S来了(在同一台主机上。即使是同一个程序,只是另一个线程):
ug_server_context = zmq.Context()
server_socket = ug_server_context.socket(zmq.REP)
server_socket.bind("tcp://*:5558")
while 1:
updated_ug_message = server_socket.recv()
server_socket.send("ug received.")
这是我的 "brokers" 使用 ROUTER 和 DEALER 的 H1 和 H2:
context = zmq.Context()
# Prepare broker sockets
frontend = context.socket(zmq.ROUTER)
backend = context.socket(zmq.DEALER)
frontend.bind("tcp://*:5556") # for H1: 5557
backend.bind("tcp://*:5557") # for H1: 5558
# Initialize broker poll set
poller = zmq.Poller()
poller.register(frontend, zmq.POLLIN)
poller.register(backend, zmq.POLLIN)
# Switch messages between sockets
while 1:
socks = dict(poller.poll())
if socks.get(frontend) == zmq.POLLIN:
message = frontend.recv_multipart()
backend.send_multipart(message)
if socks.get(backend) == zmq.POLLIN:
message = backend.recv_multipart()
frontend.send_multipart(message)
问题是,它不起作用,我的问题是:
1. H2 如何知道它必须向 H1 发送消息?
2。我的方向对吗?
好的,与此同时我自己弄明白了。我不得不改变:
backend.bind("tcp://*:5557")
至:
backend.connect("tcp://192.168.100.101:5557")
现在我的通讯戒指很好用了。