gpt4 book ai didi

python - 几次请求后 wsgiref.simple_server 出现奇怪的滞后/延迟/延迟/任何问题

转载 作者:可可西里 更新时间:2023-11-01 02:31:47 29 4
gpt4 key购买 nike

我有一个恼人的问题。我有这个简单的服务器代码(比方说):

#!/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 次尝试中有 1 次(因此大约 20% 的请求)的服务速度非常非常慢。当我在出现这种巨大延迟时中断服务器处理时,我总是会遇到以下异常:

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

您知道如何避免这种恼人的事情吗?或者这种行为背后的原因是什么?

更新一:我尝试通过修改 simple_server.py ->WSGIServer-> server_bind 函数来尝试 TCP_NODELAY,如下所示:

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()

不幸的是没有变化:(

最佳答案

您正在使用端口号 3540,这是“TCP/UDP 端口查找器”的默认端口。您可能会与操作系统上的其他服务/守护进程发生端口冲突。

您可以更改端口 80、8000、8080……如果您需要 Web 服务器。

关于python - 几次请求后 wsgiref.simple_server 出现奇怪的滞后/延迟/延迟/任何问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44220607/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com