news 2026/4/15 15:50:58

Docker部署Python FastAPI应用攻略:从构建镜像到第三方依赖缺失问题解决

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Docker部署Python FastAPI应用攻略:从构建镜像到第三方依赖缺失问题解决

目录

  • 前言
  • docker部署python fastapi
    • 基本概念
    • 生成requestment文件
    • Dockfile构建镜像
    • 启动容器
    • 容器启动失败时修复依赖缺失的解决方案,重构正确镜像

前言

  • 这篇博客讲一下如何在centos服务器上用docker部署 python应用,以及部署完成之后,发现由于缺第三方库,导致容器启动失败,无法进入容器手动安装第三方包的问题以及解决方案
  • 对docker不熟悉的朋友可以看下我的其他博客,有讲关于docker相关的知识以及多种问题的解决方案

docker部署python fastapi

基本概念

  1. Python 镜像与 Java SpringBoot 镜像的构建逻辑存在核心差异:Java 作为编译型语言,可将项目编译后的字节码文件,连同第三方依赖库的字节码文件一并打包为 JAR 包,基于该 JAR 包即可直接构建出可运行的应用镜像;而 Python 属于脚本型、解释型语言,无需编译环节,无法直接将第三方依赖库整合到项目文件中,因此在构建 Python 镜像时,需先将项目依赖的第三方库及其版本信息明确写入 requirements.txt 文件,再在镜像构建过程中通过 pip 命令将这些依赖安装到镜像内

生成requestment文件

requestment文件的内容是项目用到的第三方库以及版本信息,便于构建python应用镜像时,通过 pip 命令工具安装文件指定的第三方库到镜像内部,一个标准的requestment文件内容如下:

fastapi==0.124.4 langchain==0.3.14 langchain-community==0.3.14 langgraph==0.2.65 pydantic==2.12.5 python-dotenv==1.2.1 uvicorn==0.38.0 dashscope==1.21.0

一般在python项目根目录生成这个requestment文件,主要的生成方式有两种,

  1. 通过AI编码插件智能体自动构建,比如pycharm中可以安装通义灵码插件,直接在通义灵码插件面板选择智能体,让其生成项目的requestment文件。
  2. 第二种方式是通过python 第三方包,pipreqs工具生成,这个工具需要提前通过pip install pipreqs命令提前安装,最好安装在你的项目环境下
  3. 安装完成后,在控制台进入到你的项目根目录,执行pipreqs . --encoding=utf8 --force --ignore=".venv,venv,__pycache__",pipreqs工具会自动读取扫描当前目录及其子目录内的所有py文件,主要是读取文件的import内容,将第三方库以及版本信息创建写入到requestment.txt 文件中
  4. 值得注意的是,这两种方式无论哪一种,我都试过,生成的内容并不是很准确,存在版本冲突的问题,以及如果一个第三方库内部引用了另一个第三方库,间接引用的第三方库无法被正确写入requestment 文件内。这个问题的解决方案 在博客最后一个章节总结了解决方案。

Dockfile构建镜像

  1. 将项目根目录上传到服务器,在项目根目录中,创建Dockerfile镜像构建文件,编辑内容如下:

    # 使用官方Python 3.12的轻量级版本作为基础镜像FROM python:3.12-slim# 设置容器内的工作目录WORKDIR /app# 将依赖列表文件复制到工作目录COPY requirements.txt .# (可选但推荐)配置pip使用国内镜像源以加速本地构建RUN pip install--upgrade pip-i https://pypi.tuna.tsinghua.edu.cn/simple# 读取requirements.txt,安装第三方库到镜像内部RUN pip install-r requirements.txt-i https://pypi.tuna.tsinghua.edu.cn/simple# 将项目所有源代码复制到容器中 [4,10]COPY . .# 暴露FastAPI应用运行的端口(例如8000) [1,3]EXPOSE 8000# 设置容器启动命令 [1,4](@ref)CMD["uvicorn","main:app","--host","0.0.0.0","--port","8000"]
  2. 在构建镜像过程中docker会自动下载python:3.12-slim基础镜像,网速不好的朋友可以提前执行下面的命令,提前将python3.12基础镜像下载到服务器中。

    docker pull swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/python:3.12-slim docker tag swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/python:3.12-slim python:3.12-slim
  3. 最后在服务器,项目根目录即Dockerfile目录内执行docker build -t 镜像名称 .就构建好了你的python应用镜像

启动容器

  1. 执行docker run ,配置端口、网络、容器名等配置 启动容器

    docker run -d -p8000:8000 --name my-fastapi-container my-fastapi-app
  2. 我们 通过docker ps 命令 查看应用是否正常启动,很有可能你的python应用由于缺包导致启动失败,此时我们再通过docker logs -f 容器名 查看容器的启动日志,大概率会看到缺包导致启动失败的错误信息

容器启动失败时修复依赖缺失的解决方案,重构正确镜像

  1. 此时容器由于启动失败已经停止运行,此时我们无法通过docker exec -it 容器名 bash的方式进入容器,进而pip install 安装缺失的包,这是一个棘手的问题。

  2. 一个有效的解决方案是,不要以直接运行镜像中的python应用的方式启动容器,而是以启动命令行交互的方式启动容器,容器启动失败的核心是CMD/ENTRYPOINT执行的命令报错退出,我们可以覆盖启动命令,让容器以交互式 shell 运行(不执行原业务逻辑),从而进入容器安装缺失包

    # 注意,镜像还是之前的镜像,只是以命令行方式启动容器docker run -it --name temp-api 原先的镜像名 /bin/bash
  3. 启动后,安装缺失的包,并在容器内部的命令行中启动应用,测试是否可以正常运行,如果仍有缺失的包 ,继续安装,直到应用启动成功为止。

    # 1. 先升级pip(可选,加速安装)pipinstall--upgrade pip -i https://pypi.tuna.tsinghua.edu.cn/simple# 2. 安装缺失的包(示例:假设缺requests、langchain-core)# 替换为你实际缺失的包名pipinstall缺失包名1 缺失包名2 -i https://pypi.tuna.tsinghua.edu.cn/simple# 3. 直接在容器内运行FastAPI应用(验证依赖是否修复)uvicorn main:app --host0.0.0.0 --port8008
  4. 安装包后运行正常,把容器的修改保存为新镜像,这个新的镜像就是你的python应用最终的完整镜像。

    # 先开新终端,查看临时容器IDdockerps# 提交修改(container_id替换为临时容器的ID,new-image:tag为新镜像名)docker commit 运行正常的容器名或者id 新的镜像名:tag# 用新镜像启动业务容器docker run -d -p8000:8000 --name my-fastapi-container my-fastapi-app
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/10 20:30:23

颠覆传统体验:scrcpy如何重塑安卓设备管理生态

颠覆传统体验:scrcpy如何重塑安卓设备管理生态 【免费下载链接】scrcpy Display and control your Android device 项目地址: https://gitcode.com/gh_mirrors/sc/scrcpy 在当今数字化工作环境中,安卓远程控制技术正迎来革命性突破。scrcpy作为一…

作者头像 李华
网站建设 2026/4/9 19:10:02

构建隐私保护下的联邦学习测试数据方案

联邦学习作为一种分布式机器学习范式,允许在多个客户端(如移动设备或机构服务器)上训练模型而无需集中原始数据,从而显著增强了数据隐私和安全性。然而,这种去中心化的特性也为测试工作带来了独特挑战,尤其…

作者头像 李华
网站建设 2026/4/11 4:33:50

智慧城市系统集成测试的挑战与创新实践

智慧城市系统特性与测试范式转变 随着物联网设备数量突破百亿级(2025年Gartner数据),智慧城市系统呈现三大典型特征: 异构数据贯通:交通监控、环境传感、政务平台等跨领域数据需实现秒级融合 实时决策闭环&#xff1…

作者头像 李华
网站建设 2026/4/3 4:31:55

构建智能化软件测试新范式:人机协同测试流程设计与实践

测试行业的发展拐点 随着人工智能技术的迅猛发展和软件系统的日益复杂化,传统的软件测试方法正面临前所未有的挑战。测试用例爆炸式增长、敏捷开发周期不断缩短、用户体验要求持续提升,这些因素共同推动着测试行业走向智能化转型的关键拐点。人机协同测…

作者头像 李华
网站建设 2026/4/8 12:59:00

赋能软件测试:智能决策支持如何重塑测试投资回报

在数字化浪潮席卷全球的今天,软件已成为企业运营和创新的核心驱动力。作为软件质量保障的关键环节,软件测试的重要性不言而喻。然而,测试团队常常面临资源有限、时间紧迫、需求多变等挑战,如何在复杂的项目环境中做出科学的测试投…

作者头像 李华
网站建设 2026/4/9 1:43:49

OpenModScan:工业自动化调试的免费Modbus神器

OpenModScan:工业自动化调试的免费Modbus神器 【免费下载链接】OpenModScan Open ModScan is a Free Modbus Master (Client) Utility 项目地址: https://gitcode.com/gh_mirrors/op/OpenModScan 在工业自动化和物联网设备开发领域,Modbus通讯协议…

作者头像 李华