- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我想使用 SocketServer 模块为服务器的请求处理程序中的各个连接添加超时。
首先让我说这是我第一次尝试使用 Python 进行网络编程。我已经对 SocketServer.BaseRequestHandler 和 SocketServer.ThreadingTCPServer & SocketServer.TCPServer 进行了子分类,并设法创建了两个具有一些基本线程 TCP 功能的类。
但是我希望我的传入连接超时。试图覆盖任何内置的 SocketServer 超时值和方法是行不通的,因为文档说这只适用于 fork 服务器。我设法创建了一个在 X 秒后触发的计时器线程,但是由于处理程序线程中阻塞 recv 调用的性质,这是没有用的,因为我会被迫杀死它,这是我真正想避免。
所以我的理解是我需要一个 asyncore 实现,在那里我会收到通知并读取一定数量的数据。如果在 5 秒内没有发送任何数据,可以说,我想关闭该连接(我知道如何干净地做到这一点)。我发现了一些将 asyncore 与套接字一起使用的示例,但没有一个使用 SocketServer。那么,我该如何实现 asyncore 和 threadingTCPserver 呢?是否可以?有人做过吗?
最佳答案
您还可以在 recv
调用上设置超时,如下所示:
sock.settimeout(1.0)
由于您使用了 SocketServer
,因此您必须在 SocketServer
的某处找到底层的 socket
。请注意,SocketServer
会为您创建套接字,因此您无需自己动手。
您可能已经定义了一个 RequestHandler
来配合您的 SocketServer
。它应该看起来像这样:
class RequestHandler(SocketServer.BaseRequestHandler):
def setup(self):
# the socket is called request in the request handler
self.request.settimeout(1.0)
def handle(self):
while True:
try:
data = self.request.recv(1024)
if not data:
break # connection is closed
else:
pass # do your thing
except socket.timeout:
pass # handle timeout
关于python - SocketServer ThreadingTCPServer & Asyncore Dispatcher,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12510522/
我已经编写(大部分是复制的)一个非常简单的 python 脚本来充当 xbmc 的来电显示插件。除了关闭套接字外,它按预期工作。我已经确认 xbmc.abortRequested(XBMC 正在关闭的
我正在编写一个简单的套接字服务器,我想跟踪客户端状态(身份验证等)。每次调用 handle_read() 时,我对那个特定的客户端一无所知。如果我知道客户的 ID 之类的东西会有所帮助。这是我到目前为
我编写了一个程序,可以使用 asyncore 模块同时与许多服务器进行通信。在大多数情况下,我只是响应从服务器接收的数据,但有时我需要发送一些“不同步”的数据。默认超时为 30 秒,在发送数据包之前有
我在 python 上使用 asyncore 获得了 tcp 服务器: class AsyncClientHandler(asyncore.dispatcher_with_send): def
对于初学者,我使用了 Twisted 和 SocketServer 以及 ForkMixIn、ThreadMixIn 并尝试了“线程池”recepies。 但是,我想在 Python 中做一些特别的工
我在 python 中实现了一个基于 asyncore 的 IRC 机器人,但我无法捕获在 asyncore 分派(dispatch)类的方法中发生的异常。这是我的最小示例: #!/usr/bin/e
我开始学习这个 asyncore.dispatcher 模块,当我运行第一个示例程序时,它给出了如下错误: Python 版本 2.6 asyncore 模块已安装,其中也有调度程序类。可能是什么问题
我使用 python asyncore 编写了一个异步客户端,遇到了一些问题。我已经在这个帮助下解决了这个问题: Asyncore client in thread makes the whole p
我是 Python 的新手(尽管我已经使用 Java 编程多年),并且我正在开发一个简单的基于套接字的网络应用程序(只是为了好玩)。我的想法是,我的代码连接到一个远程 TCP 端点,然后监听从服务器推
我需要连接到服务器(例如 smpp 服务器)并每 2 秒发送一次周期性数据,代码如下: import asyncore, socket, threading, time class SClient(a
看来我可以通过两种方式用 python 做快速爬虫: 带 block 套接字的线程池 非阻塞套接字选择、asyncore 等。 我认为这里没有真正需要线程的地方,解决方案 #2 更好。 哪个更好,为什
我尝试使用 asyncore 做简单的异步 http 客户端:这段代码工作正常,输出是(足够快): www.gmail.com : recv http code: 301 www.yandex.
我想异步阅读网站,据我所知,urllib 无法做到这一点。现在我尝试使用普通套接字进行阅读,但 HTTP 让我很痛苦。我遇到了各种时髦的编码,例如 transfer-encoding: chunked
我不熟悉 asyncore ,并且除了一些扭曲教程的介绍外,对异步编程的了解非常有限。 我最熟悉线程并在我所有的应用程序中使用它们。一个特定的应用程序使用 couchdb数据库作为其接口(interf
在 pyQt 中是否有等同于 asyncore/asynchat 的东西? 如果没有,那么我相信在客户端-服务器 GUI 应用程序中使用 asyncore/asynchat 不会有问题,对吧? 最佳答
“该模块为编写异步套接字服务客户端和服务器提供了基本的基础设施。” http://docs.python.org/2/library/asyncore.html#module-asyncore 如果我
我想使用 SocketServer 模块为服务器的请求处理程序中的各个连接添加超时。 首先让我说这是我第一次尝试使用 Python 进行网络编程。我已经对 SocketServer.BaseReque
我使用 asyncore 使用“length:message”类型的协议(protocol)与远程服务器进行通信。有人可以推荐我一种从套接字读取确切字节数的方法吗?我试图使用handle_read来填
我正在构建一个小型 MMORPG,我尝试使用异步而不是线程。 1) 我如何将数据发送到某些客户端,因为在线程中,a 保存了每个客户端套接字并以字典 a 的当前方式保存其唯一的 id 作为键。那么我怎么
嗨,我是 Python 编程新手。我可以知道为什么我的服务器没有收到客户端发送的消息吗?我试图将数据从客户端发送到服务器并使服务器将其显示在控制台中... 客户端.py import asyncore
我是一名优秀的程序员,十分优秀!