Q-Logo 我的学习笔记分享

用Nuitka将Fastapi应用打包成exe

简介

Nuitka是一个用Python写的Python编译器,兼容Python 2.6, 2.7, 3.3, 3.4, 3.5, 3.6, 3.7, 3.8,及3.9,能够将Python应用打包成可执行程序或扩展模块。(Nuitka官网:http://nuitka.net/ , 源码:https://github.com/Nuitka/Nuitka)。与PyInstaller等打包工具相比,Nuitka打包出的可执行程序运行速度更快,且能够支持Numpy、Pandas等Python库。

FastAPI 是一个用于构建 API 的现代、快速(高性能)的异步 web 框架,使用 Python 3.6+ 并基于标准的 Python 类型提示。 (FastAPI官网:https://fastapi.tiangolo.com/,源码:https://github.com/tiangolo/fastapi)。FastAPI依赖于 Starlette(负责Web部分) 和 Pydantic(负责数据部分) 拥有极高的性能。

FastAPI推荐使用ASGI 服务器来运行服务,例如Uvicorn。

本文使用Nuitka将最简单的FastAPI应用打包成exe。 以打包main.py为例,用Nuitka打包后生成main.exe文件及其他dll等文件,在Windows下直接双击main.exe,启动FastAPI服务。

FastAPI应用

我们使用FastAPI官网上给的例子main.py作为要打包的应用。最后三行是在官网main.py的基础上增加的,我们将Uvicorn也在Python代码中直接调用,这样打包后就可以直接双击可执行文件启动FastAPI服务。

main.py内容如下:

from typing import Optional

from fastapi import FastAPI

app = FastAPI()

@app.get("/")

def read_root():

return {"Hello": "World"}

@app.get("/items/{item_id}")

def read_item(item_id: int, q: Optional[str] = None):

return {"item_id": item_id, "q": q}

if __name__=='__main__':

import uvicorn

uvicorn.run(app, host="0.0.0.0", port=8000)

Nuitka打包命令

使用的Python版本为3.8.3,Fastapi版本为0.63.0,Uvicorn版本为0.13.3。在main.py所在目录中打开命令行窗口,执行如下Nuitka打包命令:

python -m nuitka --standalone --mingw64 --show-memory --show-progress --nofollow-imports --include-package=uvicorn --include-package=click --include-package=h11 --include-package=starlette --include-package=fastapi --output-dir=o main.py

等待几分钟,即可打包完成。打包后会生成o/main.dist 目录,双击此目录下的main.exe即可启动FastAPI服务。服务启动后,在浏览器访问http://localhost:8000/,可查看到响应字符串

{"Hello":"World"}