第五章-综合实战:从零开始部署一个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,它是管理多容器应用的强大工具。

相关推荐
编码忘我几秒前
Spring源码又看了一遍
后端
m0_569881476 分钟前
使用Python进行网络设备自动配置
jvm·数据库·python
波诺波10 分钟前
项目pid-control-simulation-main 中的 main.py 代码讲解
开发语言·python
希望永不加班24 分钟前
SpringBoot 主启动类解释:@SpringBootApplication 到底做了什么
java·spring boot·后端·spring
一只叫煤球的猫27 分钟前
为什么不用 RAG 做记忆系统 ——压缩上下文与 memory.md 的架构选择
人工智能·后端·ai编程
巧妹儿32 分钟前
Python 配置管理封神技:pydantic_settings+@lru_cache,支持优先级,安全又高效,杜绝重复加载!
开发语言·python·ai·配置管理
智能工业品检测-奇妙智能33 分钟前
国产化系统的性价比对比
人工智能·spring boot·后端·openclaw·奇妙智能
独隅36 分钟前
Python AI 全面使用指南:从数据基石到智能决策
开发语言·人工智能·python
ZZZKKKRTSAE37 分钟前
rhel9快速上手Docker
运维·docker·容器