首先创建上下文并初始化ZMQ环境,发布者使用ZMQ_PUB绑定地址,订阅者用ZMQ_SUB连接并设置订阅主题;消息可分多部分发送,首部分为主题便于过滤,订阅者需设置空或特定主题以接收数据,且仅能收到连接后的消息,适合实时数据推送场景。

在C++项目中使用ZeroMQ实现发布/订阅模式,核心在于理解其通信模型和正确使用API。这个模式允许一个或多个发布者向多个订阅者广播消息,非常适合实时数据推送场景,比如行情更新、日志分发或设备状态同步。
配置环境与基础准备
开始前确保系统已安装libzmq库,并在项目中链接。如果使用C++封装(如cppzmq),还需引入对应的头文件。编译时记得加上-lzmq链接选项。创建任何Socket之前,必须先初始化一个上下文(context),它是整个ZeroMQ会话的根基。
- 用
zmq_ctx_new()创建上下文,程序结束前调用zmq_ctx_destroy()释放 - 发布端使用
ZMQ_PUB类型的socket,订阅端对应ZMQ_SUB - 发布者调用
zmq_bind()绑定地址,订阅者通过zmq_connect()连接到该地址
实现发布者逻辑
发布者负责将消息发送出去。你可以发送单部分或多部分消息。常见做法是第一部分作为主题(topic),第二部分为实际数据,便于订阅者过滤。
- 发送多部分消息时,在前几部分的
zmq_send()中加入ZMQ_SNDMORE标志,表示后续还有数据段 - 最后一部分发送时不带此标志,通知接收方消息结束
- 消息内容是二进制安全的,可直接传输结构体、字符串或序列化后的对象
注意:订阅者只能收到连接建立后发布的消息,早期消息不会被缓存,这是ZeroMQ的设计特点。
立即学习“C++免费学习笔记(深入)”;
编写订阅者代码
订阅者需要明确自己关心的主题,否则无法接收到任何消息。即使想接收所有消息,也需要设置一个空的订阅规则。
- 通过
zmq_setsockopt()配合ZMQ_SUBSCRIBE选项来设定感兴趣的主题 - 若希望接收所有消息,可传入空字符串作为参数;若只关注特定主题,则传入对应字符串
- 接收消息时,用
zmq_recv()读取各部分数据,并通过zmq_msg_more()判断是否还有后续部分
建议将消息接收放在独立线程中处理,避免阻塞主流程,提升程序响应性。
基本上就这些。掌握好上下文管理、套接字类型选择和通信流程,就能在C++中顺利集成ZeroMQ的发布/订阅功能。











