- 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/
我正在尝试从该网站抓取历史天气数据: http://www.hko.gov.hk/cis/dailyExtract_uc.htm?y=2016&m=1 在阅读了 AJAX 调用后,我发现请求数据的正确
我有两个 postman 请求 x,y,它们命中了两个不同的休息 api X,Y 中的端点。 x 会给我一个身份验证 token ,这是发出 y 请求所必需的。如何在请求 y 中发出请求 x ?也就是
我使用请求库通过 API 与其他服务器进行通信。但现在我需要同时发送多个(10 个或更多)POST 请求,并且只有在所有响应都正确的情况下才能进一步前进。通常语法看起来有点像这样: var optio
背景:当用户单击按钮时,其类会在class1和class2之间切换,并且此数据是通过 AJAX 提交。为了确认此数据已保存,服务器使用 js 进行响应(更新按钮 HTML)。 问题:如果用户点击按钮的
我正在将 Node.js 中的请求库用于 Google 的文本转语音 API。我想打印出正在发送的请求,如 python example . 这是我的代码: const request = requi
我经常使用requests。最近我发现还有一个 requests2 和即将到来的 requests3 虽然有一个 page其中简要提到了 requests3 中的内容,我一直无法确定 requests
我正在尝试将图像发送到我的 API,然后从中获取结果。例如,我使用发送一个 bmp 图像文件 file = {"img": open("img.bmp)} r = requests.post(url,
我发现 Google Cloud 确保移出其物理环境的任何请求都经过强制加密,请参阅(虚拟机到虚拟机标题下的第 6 页)this link Azure(和 AWS)是否遵循类似的程序?如果有人能给我指
我有一个 ASP.NET MVC 应用程序,我正在尝试在 javascript 函数中使用 jQuery 来创建一系列操作。该函数由三部分组成。 我想做的是:如果满足某些条件,那么我想执行同步 jQu
我找不到如何执行 get http 请求,所以我希望你们能帮助我。 这个想法是从外部url(例如 https://api.twitter.com/1.1/search/tweets.json?q=tw
我的应用只需要使用“READ_SMS”权限。我的问题是,在 Android 6.0 上,当我需要使用新的权限系统时,它会要求用户“发送和查看短信”。 这是我的代码: ActivityCompat.re
我的前端代码: { this.searchInput = input; }}/> 搜索 // search method: const baseUrl = 'http://localho
我有一个由 AJAX 和 C# 应用程序使用的 WCF 服务, 我需要通过 HTTP 请求 header 发送一个参数。 在我的 AJAX 上,我添加了以下内容并且它有效: $.ajax({
我正在尝试了解如何使用 promises 编写代码。请检查我的代码。这样对吗? Node.js + 请求: request(url, function (error, response, body)
如果失败(除 HTTP 200 之外的任何响应代码),我需要重试发送 GWT RPC 请求。原因很复杂,所以我不会详细说明。到目前为止,我在同一个地方处理所有请求响应,如下所示: // We
当用户单击提交按钮时,我希望提交表单。然而,就在这种情况发生之前,我希望弹出一个窗口并让他们填写一些数据。一旦他们执行此操作并关闭该子窗口,我希望发出 POST 请求。 这可能吗?如果可能的话如何?我
像 Facebook 这样的网站使用“延迟”加载 js。当你必须考虑到我有一台服务器,流量很大时。 我很感兴趣 - 哪一个更好? 当我一次执行更多 HTTP 请求时 - 页面加载速度较慢(由于限制(一
Servlet 容器是否创建 ServletRequest 和 Response 对象或 Http 对象?如果是ServletRequest,谁在调用服务方法之前将其转换为HttpServletReq
这是维基百科文章的摘录: In contrast to the GET request method where only a URL and headers are sent to the serv
我有一个循环,每次循环时都会发出 HTTP post 请求。 for(let i = 1; i console.log("succes at " + i), error => con
我是一名优秀的程序员,十分优秀!