1. 实验1
1.1 安装zmq在ubuntu虚拟机上
1.1.1 下载,./autogen.h ./configure ./make ./sudo make install ,生成到动态链接库默认安装目录是 /usr/local/lib/,头文件包含在 /usr/local/include/zmq.h
1.2 编辑helloworldserver.c 和 helloworldclient.c
1.3 分别编译 gcc -o hws -lzmq helloworldserver.c 以及 gcc -o hwc -lzmq helloworldclient.c 生成 hws 和 hwc
1.4 运行抓包软件 wireshark : sudo wireshark,打开监听 lo 回环端口(因为server 和 client 都绑定在本地lo端口)
1.5 先运行 ./hws ,然后运行 ./hwc ,可以看到 wireshark 抓到了 127.0.0.1 到 127.0.0.1 的数据
(元代马和编译后的hws\hwc都在附件 helloworld.tar.gz)
发现问题: 实验是让 hwc 发‘hello’给 hws,后者接到后发送'world'给前者,但是,wireshark 抓到的数据根本看不出来'hello'或者'world',有可能是zmq传输数据时不是原文来着。
2. 实验2
2.1 开启一个 hws ,同时开启多个 hwc,发现所有终端正常工作
2.2 开启一个hwc,同时开启多个 hws,发现只有一个 hws 响应hwc(最先启动的那个)
2.3 先开启 hwc,hwc终端界面在发了第一个数据后停在,然后开启hws,发现hwc和hws 都正常工作了
对于2.3 ,说明zmq内部有‘延迟’机制,可以在客户端比服务端先开启的情况下也正常工作,wireshark抓包分析,hwc一直在给127.0.0.1:5555端口发连接请求,但一直收到<RST,ACK>,表明这是localhost的 5555 端口还没有开启。因为代码设定的模式是S-C模式,使用TCP连接,所以wireshark结果符合我们的理解。2.1说名一个服务段可以同时为多个客户端提供服务。2.2 说明 zmq 内部对多个服务端可能造成混乱的情况做了处理,究竟什么策略,还要再看
3. 实验3
3.1 使用模式 Pub-Sub,分发-订购 ,S-C 模式下服务器绑定一个端口并监听,可以在该端口收和发数据,客户端连接服务器端口,也可以在连接上收和发数据。Pub-Sub模式下publisher 分发器绑定一个端口并分发信号,不能接受信号,subscriber 连接某个pub并接收信号,不能发送信号。 代码 wuserver.c 和 wuclient.c ,实现了pub一直分发代表天气信息的数据,sub 接收自己需要的数据(使用过滤器),代码在 weatherup.tar.gz
3.2 单独运行./wus ,抓包发现,没有任何连接数据,表明分发器在没有与任何订阅者建立连接之前,不会产生网络流量。
3.3 单独运行 ./wuc,发现sub一直往 127.0.0.1:5556 发送 SYN 信号请求建立连接,这点跟 2.3 一致。
3.4 先运行 ./ wus ,再运行 ./wuc,pub 和 sub 建立TCP连接,然后有了数据交流,从包里依然看不出是什么数据(加密了!)
3.4 运行多个 wuc(不同过滤条件),发现它们只打印自己过滤后的数据。根据文档说明,P-S的过滤是在sub段,所以每个Sub都可以接收所有数据,然后通过过滤器取所需数据
分享到:
相关推荐
在本文中,我们将深入探讨如何在Qt环境中使用ZeroMQ(ZMQ)进行网络编程,特别是实现PUB/SUB(发布/订阅)模式的进程间通信。ZeroMQ是一种强大的开源消息中间件,它提供了多种高级通信模式,使得应用程序可以轻松地...
ZMQ,全称为ZeroMQ,是一个开源的消息中间件,它提供了一种高效、灵活的异步消息传输机制。在IT行业中,ZMQ因其强大的性能和丰富的特性被广泛应用于分布式系统、微服务架构以及大数据处理等领域。本文将深入探讨ZMQ...
ZMQ(ØMQ、ZeroMQ, 0MQ)看起来像是一套嵌入式的网络链接库,但工作起来更 像是一个并发式的框架。它提供的套接字可以在多种协议中传输消息,如线程 间、进程间、TCP、广播等。你可以使用套接字构建多对多的连接...
在这个压缩包中,包含了ZMQ实现这三种通信方式所需的jar包,使得开发者无需繁琐的编译过程,可以直接在Java环境中使用。以下是关于ZMQ的三种通信模式及其相关知识点的详细解释: 1. **请求/应答模式 (Request/Reply...
这个"REP-REQ.zip_Rep和req_zmq_zmq REP_zmq REQ_zmq_req"文件包含的是一个关于ZMQ中REPLY(REP)和REQUEST(REQ)模式的示例代码,这种模式是ZMQ中的基本通信模式之一,常用于客户端-服务器架构。 **ZMQ的REPLY...
qtzmq库提供了许多与ZeroMQ相关的Qt对象,如`ZmqContext`和`ZmqSocket`,你可以通过这些对象进行消息的发送和接收。例如,创建一个`ZmqSocket`实例并连接到ZeroMQ服务器: ```cpp #include <qtzmq/ZmqSocket> Zmq...
`gRPC` 和 `ZeroMQ (zmq)` 都是实现高效通信的框架,但它们的设计理念和应用场景各有不同。本篇文章将深入探讨这两个工具,并基于提供的“grpc、zmq通信效率测试demo”进行分析。 首先,`gRPC` 是由 Google 开源的...
在这个已编译的zmq的dll文件包中,包含了适用于不同平台和编译配置的动态链接库(dll)文件,以方便在Windows系统下进行C++开发。 标题提到的"已编译的zmq的dll"指的是zeromq库的二进制形式,即动态链接库文件。在...
官方zeromq the guide翻译,直接对网页全文进行翻译,包括英文原版网页与中文版网页,可用于zmq的学习。网页内容的版本为2019年10月24日。 The Guide is originally in C, but also in PHP, Java, Python, Lua, and ...
例如,`ZMQ_PUB`用于发布者,`ZMQ_SUB`用于订阅者,`ZMQ_REQ`和`ZMQ_REP`分别对应请求和响应模式,`ZMQ_PUSH`和`ZMQ_PULL`用于推送和拉取数据。 4. **ZMQ上下文和套接字创建**: 在C语言中,首先需要创建一个`zmq_...
ZMQ被称为史上最快消息队列,它处于会话层之上,应用层之下,使用后台异步线程完成消息的接受和发送,完美的封装了Socket API,大大简化了编程人员的复杂度,被称为史上最强大的消息中间件。ZMQ是用C语言编写的,30s...
ZMQ,全称为ZeroMQ,是一款轻量级的消息中间件,它为分布式计算提供了一种高效、灵活且可扩展的框架。在ZMQ-4.3.4.zip这个压缩包中,包含了ZMQ 4.3.4版本的动态库及相关文件,用于支持在Windows平台上进行开发。 ...
window下qt通过zmq的工程,分为demo、和应用。 主要为zmq的发布订阅的实现示例,使用该demo能够轻松模拟服务端、客户端、发布者和订阅者搭配组合的使用场景。 还有dll库。
零MQ(ZeroMQ,简称ZMQ)是一个轻量级的、高性能的消息队列中间件,它提供了丰富的API,使得在不同语言中进行高效、可靠的通信成为可能。在本案例中,我们将关注如何在Qt框架下使用ZMQ进行进程间的通信。 标题"qt_...
zmq的cpp。头文件。
标题"zmq编译库和下一代nng库"提及了两个关键的通信库:ZeroMQ(zmq)和Next Generation Networking(nng)。ZeroMQ是一个广泛使用的开源消息中间件,它提供了一种高效、灵活的网络通信机制。而nng则作为ZeroMQ的下...
C#使用zmq的例子代码 namespace Server { using System; using System.Text; class Program { static void Main() { using (var ctx = new ZMQ.Context(1)) { var sock = ctx.Socket(ZMQ.REP); sock.Bind...
标题中的“zmq ios最新框架”指的是ZeroMQ(也写作ØMQ、0MQ)在iOS平台上的实现。ZeroMQ是一个开源的消息中间件库,它提供了一种轻量级的、高性能的消息传递机制,广泛用于分布式计算环境。这个框架可能是开发者...
**ZMQ库——x86与x64详解** ZMQ库,全称为ZeroMQ,是一个高度可伸缩的消息队列系统,它提供了一种在分布式计算环境中进行进程间通信(IPC)和网络间通信(IPC)的方式。ZeroMQ不仅在性能上表现出色,而且在设计上...