2017-05-27 17 views
6

私は厄介な問題があります。私はこの単純なサーバーコードを持っている(のは言わせて):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() 

生憎変更なし:(

+0

Windows 7でPython 3.4で遅滞なく動作します。32bit –

+0

Python 3.2の古いdebianマシンで遅滞なく動作します。 「非常に遅い」とはどういう意味ですか?秒? –

+0

こんにちは、私はrpi2のubuntu mateでpython3.5を使用しています。 – vpas

答えて

0

あなたはポート番号3540を使用しています、 "TCP/UDP Port Finder"のデフォルトポートです。あなたのOS上の別のサービス/デーモンとのポート衝突が可能です。

あなたはポート80,8000,8080に変更できます。

+0

何ですか?いいえ、私は19891番ポートでサーバを使用しています。 – vpas

+0

@chameleon:OKですが、このエラーがあります: '(192.168.1.100'、3540)からのリクエストの処理中に例外が発生しました。 –

+0

これはサーバーに接続しているクライアントのポートです... たとえば、私は再度クロムからサーバーをロードしようとしましたが、ポートは今は11071ですが、問題は同じです。 – vpas