zmq mysql_【ZeroMQ】轮询zmq_poll()的使用 | 学步园

该示例展示了如何使用ZeroMQ库创建一个服务器,该服务器监听来自两个不同端口的推送消息,并使用轮询机制接收来自客户端的数据。客户端通过ZMQ_PUSH将数据发送到服务器的ZMQ_PULL端口。此实现适用于多客户端同时发送数据的场景。
摘要由CSDN通过智能技术生成

注意:此时不可以用ZMQ_REP ZMQ_REQ。  因为ZMQ_REQ发送一次数据后,如果没有收到数据,不能再次发送数据。

ZmqIOServer端:

#include

#include

#include

#include

using namespace std;

#pragma comment(lib,"libzmq.lib")

void main(int argc,TCHAR*argv[])

{

void *ctx;

ctx = zmq_init(1);

assert(ctx);

void *s1;

s1 = zmq_socket(ctx,ZMQ_PULL);

assert(s1);

void *s2;

s2 = zmq_socket(ctx,ZMQ_PULL);

assert(s2);

zmq_bind(s1,"tcp://127.0.0.1:6000");

zmq_bind(s2,"tcp://127.0.0.1:7000");

while(1)

{

zmq_pollitem_t items[2];

items[0].socket = s1;

items[0].fd = 0;

items[0].events = ZMQ_POLLIN;

items[1].socket = s2;

items[1].fd = 0;

items[1].events = ZMQ_POLLIN;

int nRet = zmq_poll(items,2,-1);

if(0 == nRet)

continue;

zmq_msg_t msg;

char re_string[20] = {0};

if(items[0].revents > 0)

{

zmq_msg_init(&msg);

zmq_recv(s1,&msg,0);

memcpy(re_string,(char*)zmq_msg_data(&msg),zmq_msg_size(&msg));

cout<

zmq_msg_close(&msg);

}

if(items[1].revents > 0)

{

zmq_msg_init(&msg);

zmq_recv(s2,&msg,0);

memcpy(re_string,(char*)zmq_msg_data(&msg),zmq_msg_size(&msg));

cout<

zmq_msg_close(&msg);

}

}

zmq_close(s1);

zmq_close(s2);

zmq_term(ctx);

}

ZmqIOClient1端:

#include

#include

#include

#include

using namespace std;

#pragma comment(lib,"libzmq.lib")

void main(int argc,TCHAR*argv[])

{

void *ctx;

ctx = zmq_init(1);

assert(ctx);

void *s1;

s1 = zmq_socket(ctx,ZMQ_PUSH);

assert(s1);

zmq_connect(s1,"tcp://127.0.0.1:6000");

while(1)

{

char sd_string[20];

cout<

gets(sd_string);

zmq_msg_t msg;zmq_msg_init_size(&msg,strlen(sd_string)+1);

memcpy(zmq_msg_data(&msg),sd_string,strlen(sd_string)+1);

zmq_send(s1,&msg,0);

zmq_msg_close(&msg);

}

zmq_close(s1);

zmq_term(ctx);

}

ZmqIOClient2端:

#include

#include

#include

#include

using namespace std;

#pragma comment(lib,"libzmq.lib")

void main(int argc,TCHAR*argv[])

{

void *ctx;

ctx = zmq_init(1);

assert(ctx);

void *s1;

s1 = zmq_socket(ctx,ZMQ_PUSH);

assert(s1);

zmq_connect(s1,"tcp://127.0.0.1:7000");

while(1)

{

char sd_string[20];

cout<

gets(sd_string);

zmq_msg_t msg;

zmq_msg_init_size(&msg,strlen(sd_string)+1);

memcpy(zmq_msg_data(&msg),sd_string,strlen(sd_string)+1);

zmq_send(s1,&msg,0);

zmq_msg_close(&msg);

}

zmq_close(s1);

zmq_term(ctx);

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值