zmq.push/pull java_ZeroMQ PUSH / PULL和丢失的信息

ZeroMQ文档指出这是PUSH / PULL设置的问题,并建议采用以下模式:添加REP / REQ设置,以便在您期望固定数量的订户时提供节点协调 . 但是,如果您无法提前知道订户数量,则应考虑更改协议以更好地适应这些条件 .

//

//  Synchronized publisher

//

#include "zhelpers.h"

//  We wait for 10 subscribers

#define SUBSCRIBERS_EXPECTED  10

int main (void)

{

s_version_assert (2, 1);

void *context = zmq_init (1);

//  Socket to talk to clients

void *publisher = zmq_socket (context, ZMQ_PUB);

zmq_bind (publisher, "tcp://*:5561");

//  Socket to receive signals

void *syncservice = zmq_socket (context, ZMQ_REP);

zmq_bind (syncservice, "tcp://*:5562");

//  Get synchronization from subscribers

int subscribers = 0;

while (subscribers 

//  - wait for synchronization request

char *string = s_recv (syncservice);

free (string);

//  - send synchronization reply

s_send (syncservice, "");

subscribers++;

}

//  Now broadcast exactly 1M updates followed by END

int update_nbr;

for (update_nbr = 0; update_nbr 

s_send (publisher, "Rhubarb");

s_send (publisher, "END");

zmq_close (publisher);

zmq_close (syncservice);

zmq_term (context);

return 0;

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值