一、问题
将 fastapi 服务打包成 exe 后双击执行,命令行中不断创建服务导致cpu吃满,最后死机
二、原因
fastapi 启动时指定了多个 workers 进程
uvicorn.run(app="jsonp_test:app", host="127.0.0.1", port=12233, workers=5)
直接运行 python 脚本不会报错,也不会导致无限启动的问题,不过一旦打包成 exe 就会无限启动子进程
三、解决办法
main 方法下加入这两行代码
import multiprocessing
multiprocessing.freeze_support()
该方法作用是阻止子进程运行其后面的代码
完整代码如下
# coding:utf-8
from fastapi import FastAPI
import uvicorn
app = FastAPI()
@app.get(f"/hello")
async def hello():
return 'ok'
if __name__ == '__main__':
# 该方法作用是阻止子进程运行其后面的代码 ----
import multiprocessing
multiprocessing.freeze_support()
# ------------------------------------
# 打包前输出到命令行
uvicorn.run(app="jsonp_test:app", host="127.0.0.1", port=12233, workers=5)
这样再打包 exe 执行,就不会无限启动子进程撑爆 cpu 啦

文章讨论了将FastAPI应用打包为exe后,由于启动时指定过多worker导致CPU占用过高并可能导致死机的问题。解决方法是在主程序中加入`multiprocessing.freeze_support()`以防止子进程无限启动。
5525

被折叠的 条评论
为什么被折叠?



