首页 > 解决方案 > PyInstaller 和 FastAPI(超出最大递归深度)

问题描述

我有一个使用fastapi作为 Web 界面的 python 服务。我需要制作一个可执行文件,因此我正在使用PyInstaller

我不断收到以下错误:

File "..../miniconda3/lib/python3.7/site-packages/PyInstaller/lib/modulegraph/modulegraph.py", line 2912, in _load_package
    self._load_module(fqname, fp, buf, stuff)
File "..../miniconda3/lib/python3.7/site-packages/PyInstaller/lib/modulegraph/modulegraph.py", line 2093, in _load_module
    m = self._load_package(fqname, pathname, packagepath)

RecursionError: maximum recursion depth exceeded while calling a Python object

我添加import sys; sys.setrecursionlimit(50000)到原始 python 文件以及规范中,但仍然遇到同样的问题。

有趣的是,如果我不使用fastapi(例如,它适用于 Flask),我不会收到该错误。看起来 PyInstaller 与 fastapi 有一些问题。

有谁知道如何解决这个问题?

这是我的主要 python 函数中的代码:

from fastapi import FastAPI
import uvicorn
app = FastAPI()

if __name__ == "__main__":
    uvicorn.run("main:app", host="0.0.0.0", workers=1, port=5000)

标签: pythonpyinstallerfastapi

解决方案


我今天也遇到了同样的问题,发现问题出在Pydantic模块上。

我直接从存储库重新安装了它:

pip uninstall pydantic

pip install git+git://github.com/samuelcolvin/pydantic@master#egg=pydantic
# or with extras
pip install git+git://github.com/samuelcolvin/pydantic@master#egg=pydantic[email,typing_extensions]

这将解决最大递归深度问题,但在Uvicorn中会遇到另一个问题:

Traceback (most recent call last):
  File "logging/config.py", line 388, in resolve
AttributeError: module 'uvicorn' has no attribute 'logging'

我用Hypercorn + Uvloop替换了Uvicorn,现在效果很好。

这是我的最终代码:

from fastapi import FastAPI

app = FastAPI()


@app.get("/")
def read_root():
    return {"Hello": "World"}


if __name__ == "__main__":
    import asyncio
    import uvloop
    from hypercorn.asyncio import serve
    from hypercorn.config import Config

    config = Config()
    config.bind = ["0.0.0.0:8000"]

    asyncio.set_event_loop_policy(uvloop.EventLoopPolicy())
    loop = asyncio.new_event_loop()
    asyncio.set_event_loop(loop)

    loop.run_until_complete(serve(app, config))


推荐阅读