zmq的sub套接字订阅后,数据是否到达网卡?

问题描述

我们通常使用zmq的pub和sub套接字,进行数据的分发,一般的流程是zmq的sub套接字实现订阅,订阅后实现数据接收,数据从pub发到sub,那么如果我订阅了,但是不采用数据的接收,我们的数据包是否会到达sub端的网卡?

验证方案

验证代码

pub端



import zmq
import  time

context = zmq.Context()
url = "tcp://115.156.162.123:6555"
socketsub = context.socket(zmq.PUB)
socketsub.bind(url)


while True:
    time.sleep(0.001)

    socketsub.send(b'hello')
    print('send okay la ')


sub端



import zmq


context = zmq.Context()
url = "tcp://115.156.162.123:6555"
socketsub = context.socket(zmq.SUB)
socketsub.connect(url)
socketsub.setsockopt(zmq.SUBSCRIBE,''.encode('utf-8'))


while True:

    response = socketsub.recv()
    print('we have get one')



实验过程

sub端启用数据的接收,查看网卡的流量情况

在这里插入图片描述

zmq不启用数据接收,查看网卡流量情况

代码:



import zmq


context = zmq.Context()
url = "tcp://115.156.162.123:6555"
socketsub = context.socket(zmq.SUB)
socketsub.connect(url)
socketsub.setsockopt(zmq.SUBSCRIBE,''.encode('utf-8'))


while True:

    # response = socketsub.recv()
    print('we have get one')



网卡流量情况:
在这里插入图片描述
(仔细观察上图, 对于send 部分,其也是降低了,说明,对于每一个到达的数据我没有进行ack的确认包了,由于我发送的数据就一个字节,所以整体看来跟这个ack的确认包的长度差别不大)

结论

根据zmq的内核架构:
(工作流程参考另一篇blog:https://blog.csdn.net/weixin_42066185/article/details/107222128)

在这里插入图片描述

我们实现了订阅,由于订阅筛选是发生在数据的发出端的,因此,即使我们接手册不进行数据的接收,实际上,该数据包也会到达网卡.

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

没有水杯和雨伞的工科男

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值