当您想要协调网络上的一组节点时,PAIR套接字将不能很好地工作。这是线程和节点策略不同的少数领域之一。基本上,节点来来去去,而线程通常是静态的。如果远程节点离开并返回,PAIR套接字不会自动重新连接。
线程和节点之间的第二个显著区别是,线程的数量通常是固定的,但节点的数量却是可变的。
我们不能假设在REQ/REP对话框完成时SUB连接已经完成。如果您正在使用除inproc之外的任何传输,则不能保证出站连接将以任何顺序完成。
一个更可靠的模型可以是:
Publisher打开PUB套接字并开始发送“Hello”消息(不是数据)。
订阅者连接SUB套接字,当他们收到Hello消息时,他们通过REQ/REP套接字对告诉发布者。
当发行商得到所有必要的确认后,它就开始发送真实的数据。