第五章-综合实战:从零开始部署一个Flask应用

5.1 项目准备:一个简单的Flask应用

我们创建一个简单的Flask应用,包含以下文件:

复制代码
flask-demo/
├── app.py          # 应用主文件
├── requirements.txt # 依赖列表
└── Dockerfile      # Docker配置文件

app.py内容:

python 复制代码
from flask import Flask
import redis
import os

app = Flask(__name__)

# 从环境变量获取Redis地址,默认localhost
redis_host = os.environ.get('REDIS_HOST', 'localhost')
r = redis.Redis(host=redis_host, port=6379, decode_responses=True)

@app.route('/')
def hello():
    # 访问计数器
    count = r.incr('hits')
    return f'Hello World! I have been seen {count} times.'

if __name__ == '__main__':
    app.run(host='0.0.0.0', port=5000)

requirements.txt内容:

复制代码
Flask==2.1.0
redis==4.3.0

5.2 编写Dockerfile

Dockerfile内容:

dockerfile 复制代码
# 使用Python 3.9精简版作为基础镜像
FROM python:3.9-slim

# 设置工作目录
WORKDIR /app

# 复制依赖文件并安装依赖
COPY requirements.txt .
RUN pip install -r requirements.txt

# 复制应用代码
COPY . .

# 暴露端口
EXPOSE 5000

# 启动应用
CMD ["python", "app.py"]

5.3 构建和运行

5.3.1 构建镜像

bash 复制代码
# 在flask-demo目录下执行
docker build -t flask-demo:1.0 .

5.3.2 运行容器

由于我们的应用依赖Redis,需要先启动Redis容器:

bash 复制代码
# 启动Redis容器
docker run -d --name my-redis redis:alpine

# 启动Flask应用容器,链接到Redis容器
docker run -d -p 5000:5000 --name my-flask --link my-redis:redis flask-demo:1.0

5.3.3 验证部署

打开浏览器访问http://localhost:5000,应该能看到"Hello World! I have been seen X times."的页面,每次刷新数字都会增加。

5.4 优化改进

5.4.1 使用Docker Compose简化多容器部署

创建docker-compose.yml文件:

yaml 复制代码
version: '3'
services:
  redis:
    image: redis:alpine
    container_name: my-redis
    
  flask:
    build: .
    image: flask-demo:1.0
    container_name: my-flask
    ports:
      - "5000:5000"
    environment:
      - REDIS_HOST=my-redis
    depends_on:
      - redis

然后只需一条命令即可启动整个应用:

bash 复制代码
docker-compose up -d

这个实战项目展示了如何将一个真实的应用通过Docker进行容器化部署,涵盖了镜像构建、容器运行、多容器协作等多个知识点。

下一章,我们将学习Docker Compose,它是管理多容器应用的强大工具。

相关推荐
咖啡の猫9 小时前
Python字典推导式
开发语言·python
曹文杰15190301129 小时前
2025 年大模型背景下应用统计本科 计算机方向 培养方案
python·线性代数·机器学习·学习方法
掘金码甲哥9 小时前
🚀糟糕,我实现的k8s informer好像是依托答辩
后端
GoGeekBaird10 小时前
Andrej Karpathy:2025年大模型发展总结
后端·github
Wulida00999110 小时前
建筑物表面缺陷检测与识别:基于YOLO11-C3k2-Strip模型的智能检测系统
python
uzong10 小时前
听一听技术面试官的心路历程:他们也会有瓶颈,也会表现不如人意
后端
Jimmy10 小时前
年终总结 - 2025 故事集
前端·后端·程序员
FJW02081410 小时前
Python_work4
开发语言·python
爱笑的眼睛1111 小时前
从 Seq2Seq 到 Transformer++:深度解构与自构建现代机器翻译核心组件
java·人工智能·python·ai
yaoh.wang11 小时前
力扣(LeetCode) 88: 合并两个有序数组 - 解法思路
python·程序人生·算法·leetcode·面试·职场和发展·双指针