python zmq xpub/xsub

本文介绍了一个使用ZeroMQ库实现的消息发布与订阅系统示例。该系统包括一个发布者节点,不断发送带有数字计数的消息;一个订阅者节点,订阅特定前缀的消息并打印接收到的内容;以及一个代理节点,负责连接前端的发布者与后端的订阅者。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#!/usr/bin/python
# -*-coding:utf-8-*-

import zmq
import time

context = zmq.Context()
socket = context.socket(zmq.PUB)
socket.connect("tcp://127.0.0.1:5555")
idx = 0
while True:
    msg = str(idx) + " 11111111"
    # socket.send_string(msg)
    socket.send_string("%d %s" % (1, msg))
    socket.send_multipart((b'10', b'aaaaaaaaaaaaaaaaaaaaaaaaa'))
    time.sleep(1)
    idx += 1

 

#!/usr/bin/python
# -*-coding:utf-8-*-

import zmq
import time

context = zmq.Context()
socket = context.socket(zmq.SUB)
socket.setsockopt_string(zmq.SUBSCRIBE, '1')
# socket.setsockopt_string(zmq.SUBSCRIBE, '2')
socket.setsockopt_string(zmq.SUBSCRIBE, '30')
socket.connect("tcp://127.0.0.1:5556")
socket.setsockopt_string(zmq.UNSUBSCRIBE, '3')

idx = 0
while True:
    # msg = socket.recv_string()
    msg = socket.recv_multipart()
    print(idx, '==', type(msg), msg)
    idx += 1
#include <stdio.h>
#include <zmq.h>

int main ()
{
    // 1.创建新的上下文
    void *context = zmq_ctx_new ();

    // 2.前端套接字, 用于连接内部的天气服务器
    void *frontend = zmq_socket (context, ZMQ_XSUB);
    zmq_bind (frontend, "tcp://127.0.0.1:5555");

    // 3.后端套接字, 用来处理外部的订阅者的请求
    void *backend = zmq_socket (context, ZMQ_XPUB);
    zmq_bind (backend, "tcp://127.0.0.1:5556");

    // 4.持续运行代理
    zmq_proxy (frontend, backend, NULL);

    // 5.关闭套接字、清除上下文
    zmq_close (frontend);
    zmq_close (backend);
    zmq_ctx_destroy (context);

    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值