私は厄介な問題があります。私はこの単純なサーバーコードを持っている(のは言わせて):2つのリクエストの後でwsgiref.simple_serverで奇妙な遅延/遅延/遅延/何でも
#!/usr/bin/env python3
import wsgiref.simple_server
def my_func(env, start_response):
start_response('200 OK', [])
return [''.encode()]
server = wsgiref.simple_server.make_server(
'0.0.0.0',
19891,
my_func,
)
server.serve_forever()
しかし、5回の試行(リクエストのように約20%)から1時間が非常に-非常に遅い提供しています。私は、サーバーの処理を中断すると、この巨大な遅延が所定の位置にあるとき、私はいつも、以下の例外が取得しています:
Exception happened during processing of request from ('192.168.1.100', 3540)
Traceback (most recent call last):
File "/usr/lib/python3.5/socketserver.py", line 313, in _handle_request_noblock
self.process_request(request, client_address)
File "/usr/lib/python3.5/socketserver.py", line 341, in process_request
self.finish_request(request, client_address)
File "/usr/lib/python3.5/socketserver.py", line 354, in finish_request
self.RequestHandlerClass(request, client_address, self)
File "/usr/lib/python3.5/socketserver.py", line 681, in __init__
self.handle()
File "/usr/lib/python3.5/wsgiref/simple_server.py", line 119, in handle
self.raw_requestline = self.rfile.readline(65537)
File "/usr/lib/python3.5/socket.py", line 575, in readinto
return self._sock.recv_into(b)
KeyboardInterrupt
をあなたはこの迷惑な事を避けるために、どのように任意のアイデアを持っていますか?または、この行動の背後にある理由は何でしょうか?
アップデート1: 私はsimple_server.py変更でTCP_NODELAYを試してみました - 以下のように> WSGIServer-> server_bind機能を:
def server_bind(self):
"""Override server_bind to store the server name."""
import socket
self.socket.setsockopt(socket.IPPROTO_TCP, socket.TCP_NODELAY,1)
HTTPServer.server_bind(self)
self.setup_environ()
生憎変更なし:(
Windows 7でPython 3.4で遅滞なく動作します。32bit –
Python 3.2の古いdebianマシンで遅滞なく動作します。 「非常に遅い」とはどういう意味ですか?秒? –
こんにちは、私はrpi2のubuntu mateでpython3.5を使用しています。 – vpas