zeromq发布pub和订阅sub

pub

#include "stdafx.h"

#include <stdio.h>
#include <stdlib.h>


#include <assert.h>
#include <string>
#include <zmq.h>


using namespace std;


int main()
{
printf("Hello world!\n");


void* context = zmq_ctx_new();///创建一个新的环境
assert(context != NULL);


int ret = zmq_ctx_set(context, ZMQ_MAX_SOCKETS, 1);/// 在该环境中最大只允许一个socket存在
assert(ret == 0);


void* publisher = zmq_socket(context, ZMQ_PUB);/// 创建一个发布者
assert(publisher != NULL);


ret = zmq_bind(publisher, "tcp://192.168.1.128:8888");/// 绑定该发布到TCP通信
assert(ret == 0);


int i = 0; 
while (1)
{

std::string str;
str = "Hi,I'm server";
int n = str.size();
char buff[20];
memset(buff, 0, 20);
sprintf_s(buff, "Hi,I'm server %d\n", i);
n = str.size();
//ret = zmq_send(publisher, buff, 20, 0);/// 发送消息
  //assert(ret == 7);
printf("%s\n", buff);
Sleep(10);
i++;
}


printf("1\n");


return 0;

}


sub

#include "stdafx.h"
#include <stdio.h>
#include <stdlib.h>
//#include <unistd.h>
#include <assert.h>
#include <zmq.h>


int main()
{
printf("Hello world!\n");


void* context = zmq_ctx_new();/// 创建一个新的环境
assert(context != NULL);


int ret = zmq_ctx_set(context, ZMQ_MAX_SOCKETS, 1);/// 该环境中只允许有一个socket的存在
assert(ret == 0);


void* subscriber = zmq_socket(context, ZMQ_SUB);/// 创建一个订阅者
assert(subscriber != NULL);


ret = zmq_connect(subscriber, "tcp://192.168.1.128:8888");/// 连接到服务器
assert(ret == 0);


ret = zmq_setsockopt(subscriber, ZMQ_SUBSCRIBE, "", 0);/// 必须添加该语句对消息滤波,否则接受不到消息
assert(ret == 0);


char buf[20];/// 消息缓冲区
while (1)
{
ret = zmq_recv(subscriber, buf, 20, ZMQ_DONTWAIT);/// 接收消息,非堵塞式
if (ret != -1)/// 打印消息
{
buf[ret - 1] = '\0';
printf("sub:%s\n", buf);
}
Sleep(1);
}






return 0;
}



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ZeroMQ发布订阅模式(Publish-Subscribe)是一种常用的消息传递模式,适用于需要发布订阅消息的场景,例如多人聊天室、订阅新闻、实时数据传输等。 在发布订阅模式中,消息发布者(Publisher)将消息发送到一个或多个主题(Topic),消息订阅者(Subscriber)可以根据自己的需求订阅感兴趣的主题,从而接收到相应的消息。发布订阅模式支持一对多和多对多的消息传递,可以实现广播、多播等功能。 具体实现时,可以使用 ZeroMQPUB-SUB 套接字组合来实现发布订阅模式。消息发布者使用 PUB 套接字将消息发送到指定的主题,消息订阅者使用 SUB 套接字订阅感兴趣的主题,并接收相应的消息。需要注意的是,订阅者必须在发布者发送消息之前订阅相应的主题,否则无法接收到消息。 以下是使用 ZeroMQ 实现发布订阅模式的示例代码: Publisher: ```python import zmq context = zmq.Context() socket = context.socket(zmq.PUB) socket.bind("tcp://*:5555") while True: topic = input("Enter topic: ") message = input("Enter message: ") socket.send_string(f"{topic} {message}") ``` Subscriber: ```python import zmq context = zmq.Context() socket = context.socket(zmq.SUB) socket.connect("tcp://localhost:5555") topic_filter = input("Enter topic filter: ") socket.setsockopt_string(zmq.SUBSCRIBE, topic_filter) while True: message = socket.recv_string() topic, content = message.split(' ', 1) print(f"[{topic}] {content}") ``` 在这个示例中,消息发布者通过 PUB 套接字将消息发送到指定的主题,消息订阅者通过 SUB 套接字订阅感兴趣的主题,并接收相应的消息。需要注意的是,订阅者必须在发布者发送消息之前订阅相应的主题,否则无法接收到消息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值