- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我想利用 ZMQ 来实现(在 python 中)一个代理和一个客户端,用于异步处理对寻址实体的请求-回复。客户端包含执行请求和回复的功能(唯一缺少的是确切的套接字类型/模式)。
请求可以是阻塞的,但回复端需要能够处理传入的并行(线程)请求。(即 REP 套接字不够好,因为它需要在下一次接收之前发送)
它需要通过代理,因为有许多可能的实体可以执行请求和回复,而我只想绑定(bind)一组端口(不是每个实体一个)。
Entity1 Broker Entity2
REQ ------------- ROUTER ?????? -------------- ??????
Entity1 将知道 Entity2 的 ID,并使用它来确保请求是专门向 Entity2 发出的。可以有任意数量的实体,但所有应响应请求的实体都将注册 ID。
我尝试过在上面的代理右侧使用 DEALER,但该经销商似乎只会循环发送请求。
那么有人知道我可以使用一个好的模式/套接字集来异步寻址特定实体吗?
摘要:
我已经相当广泛地阅读了 ZMQ 手册,但我还没有找到任何真正好的模式来通过代理寻址特定套接字,因此非常感谢任何帮助。
最佳答案
经过进一步的研究和测试,我发现了一种模式,它似乎可以为我的所有需求提供解决方案。
模式
Requester Broker Replier
REQ ------------- ROUTER ROUTER -------------- DEALER
(requests) (replies)
请求者
客户端的请求端只需连接到代理上的请求路由器,发送请求并开始读取套接字以获取回复:
reqSocket.connect(self._reqAddress)
reqSocket.send_multipart([repId, message])
reply = reqSocket.recv_multipart()[0]
回复者 ID 作为消息的第一部分包含在内,例如:
Outgoing message: ['replierId', 'requestMsg']
请求路由器
if self.reqRouterSocket in socketEvents:
multipart = self.reqRouterSocket.recv_multipart()
multipart = [multipart[-2]] + multipart
del multipart[-2]
self.repRouterSocket.send_multipart(multipart)
即,请求路由器仅移动有效负载的第一部分(即replierId)并将其放在地址堆栈中的第一个部分:
Incoming message: ['reqSocketAddr', '', 'replierId', 'requestMsg']
Outgoing message: ['replierId', 'reqSocketAddr', '', 'requestMsg']
传出消息是从回复路由器发送的。由于回复者将其套接字 ID 设置为“replierId”并已连接到回复者路由器,因此该路由器可以识别该地址并能够成功传送请求。
回复者
回复者需要将其自己的套接字标识设置为某个已知值,以便如上所述直接寻址。
注意:在执行与回复路由器的连接之前,您必须设置 DEALER 套接字的套接字 ID。设置套接字的身份:
self.dealerSocket.setsockopt(zmq.IDENTITY, 'replierId')
否则路由器将不知道ID并会抛出消息。
应答器监听传入的请求。就我而言,这都是线程化的,并且请求是异步处理的。这就是使用 DEALER 套接字而不是常规 REP 的原因,在同步情况下这会容易得多。 DEALER 套接字可以接收更多请求,而不必首先回答第一个请求,而 REP 必须这样做。然而,回复者端所做的事情的简化版本是:
multipart = self.dealerSocket.recv_multipart()
returnRoute = multipart[:-1]
requestMsg = multipart[-1]
reply = someFunction(requestMsg)
self.dealerSocket.send_multipart(returnRoute + [reply])
即,回复者只返回它得到的内容,但请求已更改为回复:
Incoming message: ['replierId', 'reqSocketAddr', '', 'request']
Outgoing message: ['replierId', 'reqSocketAddr', '', 'reply']
此传出消息随后被发送回回复路由器。
回复路由器
在代理的这一侧选择路由器纯粹是因为它需要在许多连接的套接字中寻址特定套接字的功能。
if self.repRouterSocket in socketEvents:
multipart = self.repRouterSocket.recv_multipart()
self.reqRouterSocket.send_multipart(multipart[1:])
即,弹出地址栈的首地址,然后再次将消息发送给请求方。
Incoming message: ['replierId', 'reqSocketAddr', '', 'reply']
Outgoing message: ['reqSocketAddr', '', 'reply']
请求路由器识别该地址并将请求发送回请求者,请求者接收:
Incoming list: ['reply']
这种模式似乎满足我在问题中提出的要求。我希望它对其他人也有用。
关于python - 用于寻址异步请求的 ZMQ Python 请求回复代理,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28051277/
我有多个 InOut 模式的顺序队列,每个队列通向一个 Camel 处理器。如果处理器花费太多时间进行处理,我希望请求-答复检测到超时并发送 ExchangeTimedOutException。Cam
我是一名学生,试图了解更多关于 C# 中的 ARP 和套接字的信息 为此,我尝试使用原始 Socket 发送 ARP 请求和回复。在 C# 中。 我已经在一个字节数组中手动重建了一个 ARP 回复
我正在使用 Amazon Web Services 数据库 dynamodb。它返回一个 JSON,看起来像这样: {"Responses":{"friends":[{"to_username":"u
我有 servlet,它创建 html 文件,然后将其转换为 pdf 文件: private void ConvertHTMLtoPDF(String sConvertationProgramm, S
我正在为我的项目使用 Mailkit 库 (Imap)。 我可以轻松地通过 SmtpClient 发送新消息。 目前我正在研究如何回复特定邮件。是否可以向该回复邮件添加更多收件人? @jstedfas
这个问题已经有答案了: How to parse JSON in Java (36 个回答) 已关闭 7 年前。 请您告诉我如何解析 JSON 回复。我从 https://api.privatbank
我正在尝试从事 YouTube 视频评级工作。但我被困在这里了。这两个 YouTube 评级请求有什么区别? https://www.googleapis.com/youtube/v3/videos/
我搜索了该网站,令人惊讶的是没有找到任何适合我情况的答案。所以我发布了这个问题。 我正在使用 jQuery AJAX 来获取网页并将其动态添加到网站。但我的代码不起作用并抛出错误 ERROR Type
我正在编写一个 C 程序来搜索本地网络上的 smb 共享并安装它们。为了获取找到的 smb 服务器的主机名,我向服务器发送了 udp nbns 数据包。数据包正确,服务器回复。我正在使用wiresha
我正在尝试使用 Java 创建自己的 WebSocket 服务器。 当我的客户端连接时,我收到以下请求: (14): GET / HTTP/1.1 (18): Upgrade: WebSocket (
我正在使用 Nodejs、Express、MySQL、EJS。 用户能够创建帖子和评论/回复评论/回复对这些帖子的回复。 问题:我不知道如何以允许我在 EJS 中呈现它们的方式将数据分类为对象/数组。
我正在用 .NET c++ 编写程序。我正在本地网络上发送广播 ping。我的所有目标设备都能够响应 ping 广播,事实上我在 Wireshark 中跟踪了它们的所有响应。我的目标是检索所有响应站点
我有一个向 JMS MDB 发送请求的客户端。它可以很好地向 MDB 发送消息,但我一辈子都无法弄清楚如何让客户端接收 MDB 发回给它的响应。 编辑:客户端代码是同一实例上的 Web 服务,使用 @
我使用钩子(Hook)函数制作了一个模块。它可以工作,但是当我使用 ping google.com 时,我得到 0045 作为 icmp 类型。但我认为它应该是 0 用于回显回复。我使用了以下打印命令
我正在用 C 从头开始编写一个网络库。我已经实现了以太网协议(protocol),现在我想让 ARP 工作。发送请求/回复工作正常,但接收工作不正常。当我发送一个发送请求并等待它之后的回复时,re
我在替换字符串的一部分时遇到问题。现在这段代码。我的目标是针对包含此字典中的键的每个字符串。 mapping = { "St": "Street", "St.": "Stree
我有一个 WCF p2p 网状网络,它运行良好,适合单向对话。我正在研究是否可以调用一种方法来添加两个数字并返回和总和。 但是我在尝试连接时遇到错误: 契约(Contract)需要请求/回复,但绑定(
大家好,我正在尝试使用分块编码流式传输多媒体数据。因此,我首先尝试使用分块编码发送文本数据。 这是我的代码。我创建了一个服务器套接字,我在上面监听请求(端口 80),回复请求,然后我的程序终止。无论您
我的 Servlet 中有一些图像,我想将它们下载到我的 Android 应用中。 我正在对这个 URL 执行一个 GET 请求: public static final String URL ="h
文档:https://developers.google.com/apps-script/reference/gmail/gmail-message#replybody-options 当跟进一封电子
我是一名优秀的程序员,十分优秀!