1.准备工作
确保你的项目目录结构清晰,例如:
your_project/
├── app.py
├── requirements.txt
├── routes/
│ ├── router1.py
│ ├── router2.py
├── app.log (生成的文件)
2. 创建 requirements.txt
在项目根目录下创建 requirements.txt
运行以下命令生成 requirements.txt:
# 安装
pip install pipreqs
# 在当前目录生成
pipreqs . --encoding=utf8 --force
3.创建Dockerfile
在项目根目录下创建 Dockerfile 文件,内容如下:
# 使用官方 Python 镜像作为基础镜像
FROM python:3.9-slim
# 设置工作目录
WORKDIR /app
# 复制 requirements.txt 并安装依赖
COPY requirements.txt .
RUN pip install --no-cache-dir -r requirements.txt
# 复制项目文件到容器
COPY . .
# 设置环境变量,确保 Flask 以正确的方式运行
ENV FLASK_APP=app.py
ENV FLASK_ENV=production
# 暴露 Flask 运行的端口
EXPOSE 5000
# 启动 Flask 应用
CMD ["flask", "run", "--host=0.0.0.0", "--port=5000"]
说明:
- python:3.9-slim 是一个轻量级的 Python 镜像,适合生产环境。
- WORKDIR /app 设置容器内的工作目录。
- COPY requirements.txt . 和 RUN pip install 先安装依赖,避免重复构建。
- ENV FLASK_ENV=production 确保 Flask 以生产模式运行(禁用调试模式)。
- CMD 使用 flask run 启动应用,绑定到 0.0.0.0:5000 以允许外部访问。
5.创建 .dockerignore 文件
在项目根目录创建 .dockerignore,以排除不必要的文件,减小镜像体积:
__pycache__
*.pyc
*.pyo
*.pyd
.Python
env/
venv/
*.log
6. 构建 Docker 镜像
在项目根目录下运行以下命令构建镜像
docker build -t my-flask-app .
(可选) 构建镜像时指定架构
docker build --platform linux/amd64 -t my-flask-app .
- -t my-flask-app:给镜像命名(可自定义)。
- .:指定当前目录为构建上下文。
7.运行 Docker 容器
构建完成后,运行容器:
docker run -d -p 5003:5000 -v $(pwd)/logs:/app my-flask-app
- -d:后台运行容器。
- -p 5000:5000:将容器内的 5000 端口映射到宿主机的 5003 端口。
- -v $(pwd)/logs:/app:将宿主机的 logs 目录挂载到容器内的 /app,用于持久化存储 app.log 文件。需确保宿主机有 logs 目录
mkdir logs - //-v $(pwd):/app:将项目目录挂载到/app
8.可选:使用 Docker Compose
为简化部署和管理,可以使用 docker-compose.yml:
version: '3.8'
services:
app:
build: .
ports:
- "5003:5000"
volumes:
- ./logs:/app
environment:
- FLASK_ENV=production
后台运行命令:
docker-compose up -d
停止服务:
docker-compose down
查看服务日志:
docker-compose logs
8. 验证部署
访问 http://:<宿主机IP>500,确认 Flask 应用是否正常运行。
9.注意
如果字体缺失,安装字体
# 在 Dockerfile 中添加字体安装
RUN apt-get update && apt-get install -y fonts-wqy-zenhei


5954

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



