ZeroMQ用于环形拓扑 - 如何配置套接字?

时间:2016-12-03 12:43:49

标签: python zeromq messaging

我正在尝试使用ZeroMQ连接环形拓扑中的多个主机。但是经过很长一段时间的努力,我希望现在能得到一些帮助。

基本上我有一个客户端C通过几个主机H1 ... Hn向自己发送消息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 docextended 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.")

这是我使用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。我是朝着正确的方向前进的吗?

1 个答案:

答案 0 :(得分:0)

好的,与此同时我自己想出来了。我不得不改变:

backend.bind("tcp://*:5557")

为:

backend.connect("tcp://192.168.100.101:5557")

现在我的通讯铃很有效。