gpt4 book ai didi

python-3.x - aiohttp:如何最好地缓解 "OSError: Too many open files"

转载 作者:行者123 更新时间:2023-12-01 04:31:48 26 4
gpt4 key购买 nike

我有一个带有 HTTP 端点的 aiohttp (3.4.4) 服务器,该端点将文件作为输入(客户端发出多部分表单 POST)。我有一个测试客户端,可以向端点发送 10K POST。服务器端点如下所示:

async def event_handler(request):
files = await request.post()
file_field = files['file_from_client']
file_contents = file_field.file.read()

间歇性地,当我的端点尝试查看 POST 有效负载中提供的文件时,我收到以下异常:
"~/venv/python3.7/site-packages/aiohttp/web_protocol.py", line 390, in start
"~/venv/python3.7/site-packages/aiohttp/web_app.py", line 366, in _handle
"~/projects/my_project/controllers.py", line 58, in event_handler
"~/venv/python3.7/site-packages/aiohttp/web_request.py", line 585, in post
"~/venv/python3.7/tempfile.py", line 618, in TemporaryFile
"~/venv/python3.7/tempfile.py", line 258, in _mkstemp_inner
OSError: [Errno 24] Too many open files: '/tmp/tmpjnt4eu_k'

(注意:event_handler 的第 58 行是“await request.post()”行)

我知道是什么原因造成的。我的进程的文件描述符限制设置为默认值 1024,并且我的客户端在我的服务器上抛出了足够多的请求,以至于超出了该限制。我的问题是我不确定最好的服务器缓解是什么。

This article提到这个问题,有两种可能的解决方案:增加服务器进程的文件描述符数量,或者在客户端引入信号量以确保永远不会向服务器发送许多请求。后者对于测试问题都很好,但我不控制生产中的客户端。前者很容易完成,并减轻了这个特定问题,但它似乎只是提高了天花板 - 有足够的请求,似乎仍然会发生这个问题。

是否可以对 aiohttp 服务器尝试一次处理的请求数量进行限制,并让其他服务器排队等待?

最佳答案

aiohttp 接受所有传入的连接,似乎我们无法改变这一点,但是 aiohttp 前面的一个反向代理可以处理它。

例如Nginx 有 a module为了它。

关于python-3.x - aiohttp:如何最好地缓解 "OSError: Too many open files",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53528661/

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