- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
在 Twisted 中有 1 天的经验,我尝试安排消息发送以回复 tcp 客户端:
import os, sys, time
from twisted.internet import protocol, reactor
self.scenario = [(1, "Message after 1 sec!"), (4, "This after 4 secs"), (2, "End final after 2 secs")]
for timeout, data in self.scenario:
reactor.callLater(timeout, self.sendata, data)
print "waited %d time, sent %s\n"%(timeout, data)
现在它发送消息了,但是我有两个问题:
1)“超时”是从“现在”开始的,我想在每个之前的任务完成后(发送之前的消息)
2) 发送完所有消息后,我不知道如何关闭连接。如果我将 self.transport.loseConnection()
放在 callLater
之后,它会立即关闭连接。
在之前的尝试中,我没有使用 reactor.callLater
,而只使用了 self.transport.write()
和 time.sleep(n)
for
循环中的。在这种情况下,所有消息都在所有超时后一起发送……这不是我想要的。
目的是等待客户端连接,等待超时 1 并发送消息 1,等待超时 2 并发送消息 2,...等。最后一条消息后 - 关闭连接。
最佳答案
在使用 Twisted 时要意识到的重要一点是没有什么可以等待。当您调用 reactor.callLater()
时,您是在要求 react 堆稍后调用某些东西,而不是现在。调用立即完成(在调用被安排之后,之前它被执行。)因此,你的 print
语句是一个谎言:你没有等待 超时
时间;你根本就没有等。
您可以通过多种方式修复它,使用哪种方式取决于您的实际需要。如果您希望第二个任务在第一个任务开始后四秒开始,您可以简单地将第一个任务的延迟(您的timeout
变量)添加到第二个任务。但是,第一个任务可能不会在您安排的时候准确开始;它可能会稍后开始,如果 Twisted 太忙而无法早点开始。此外,如果您的任务需要很长时间,则可能在第二个任务开始之前实际上并未完成。
更常见的方式是第一个任务调度第二个任务,而不是马上调度第二个任务。您可以在第一个任务结束后四秒安排它(通过在第一个任务结束时调用 reactor.callLater()
),或者在第一个任务开始后四秒(通过调用 reactor .callLater()
在第一个任务的开始),或者执行更复杂的计算来确定它应该何时开始,跟踪耗时。
当您在 Twisted 等待中什么都没有意识到时,在您执行完所有计划任务后处理关闭连接变得很容易:您只需让最后一个任务调用 self.transport.loseConnection()
。对于更复杂的情况,您可能希望将 Deferred
链接在一起,或者使用 DeferredList
在所有未决任务完成时执行 loseConnection()
,即使它们不是严格连续的。
关于Python 扭曲 : how to schedule?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3302185/
以下代码在2端口上监听,当有消息时修改全局dict对象。并且有一个计时器也会修改字典。 d = {} class x(Protocol): def dataReceived(self, dat
Twisted 怎么样?知道函数应该以异步方式执行吗? 异步函数应该返回一个带有call-/errbacks的Deferred(immeadiately),当收到“异步”数据时将被调用。接收到的数据作
我扭曲了服务器。它与插件一起运行。我想根据请求为每个条目编写唯一的前缀。 这意味着当user1发出请求时,它将生成一个唯一的字符串,该字符串将以日志记录为前缀(仅用于此请求)。当user2发出请求时,
我正在使用校准的立体声对进行稀疏重建。这是我一步一步采取的方法: 1- 我使用 MATLAB 中的立体相机校准器应用程序校准了我的立体相机。 2-我拍摄了一对立体图像,并对每个图像进行了不失真处理。
我关注了这个tutorial但我不知道如何从服务器获取响应数据。 class Service(Resource): def render_POST(self, request):
我的网站上有一个页面,它从数据库中获取大量图像并将它们放在一个网格中。 图像的形状和大小各不相同。 我想要做的是显示图像,每个图像都具有相同的宽度和高度,但不会扭曲。 现在我的CSS是 .image{
我正在尝试创建一个简单的代金券程序。 客户端连接到服务器并询问凭证上是否还有时间,如果是,服务器会响应多少时间。 我控制服务器和客户端,客户端也由我编写代码。 现在这就是我的服务器端,客户端是不言自明
假设我通过 TCP 连接快速接收数据。我必须对其进行某种处理。因为我不想阻塞 react 器线程,所以我将处理卸载到后台线程。 数据到达的速度超过了我处理它的速度。如果我将数据放入队列中,队列会无限增
我有一个简单的客户端,它向服务器发送请求并接收响应: from StringIO import StringIO from twisted.internet import reactor fro
我目前正在使用 python/twisted 构建一个 http 服务器。 该服务器必须在另一个 Web 服务器上获取内容,将其存储在本地并将响应发送回客户端。如果遇到 404,它必须尝试提供本地文件
我有一个扭曲的 react 堆监听传入的数据。我有第二个 react 器在特定时间间隔执行 http 请求,将结果发送到第一个 react 器。两者都运行良好。 现在我想把它放在一起在一个 react
我正在尝试使用 ImageMagick 的透视 功能。我看过这些例子,但我无法理解值对应的是什么。我有这段代码: var stream = new MemoryStream(); using (Mag
我有一个应用程序的想法,该应用程序采用每个角落有四个正方形的打印页面,并允许您在至少有两个正方形可见的情况下测量纸上的对象。我希望能够让用户从不太完美的角度拍照,但仍能准确测量物体。 由于我在该领域缺
我试图让用户在文本框中输入文本,并让程序生成所有可能的组合,但最少 3 个字符和最多 6 个字符除外。我不需要像 ' 这样的无用词as'、'a'、'i'、'to' 等弄乱了我的阵列。我还将根据字典检查
给定一个包含 +ve 和 -ve 整数的数组,找出不允许跳过 2 个连续元素的最大总和(即,您必须至少选择其中一个才能向前移动)。 例如:- 10、20、30、-10、-50、40、-50、-1、-3
什么时候应该使用 twisted.python.failure.Failure,什么时候应该使用 twisted.internet.error.ConnectionDone?或者我应该做 twiste
在 Twisted 中有 1 天的经验,我尝试安排消息发送以回复 tcp 客户端: import os, sys, time from twisted.internet import protocol
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
更新:为了便于阅读,这里是如何在 react 器关闭之前添加回调: reactor.addSystemEventTrigger('before', 'shutdown', callable) 原始问题
所以我已经查看了一些涉及使用 python 和 Twisted 框架编写 HTTP 代理的事情。 基本上,就像其他一些问题一样,我希望能够修改将发送回浏览器的数据。也就是说,浏览器请求资源,代理将获取
我是一名优秀的程序员,十分优秀!