Docker Compose 用于管理多容器协同应用,通过 docker-compose.yml 定义服务配置与依赖;推荐多阶段构建分层 Python 镜像以减小体积、提升 CI 效率;GitHub Actions 实现测试、构建、部署流水线;生产环境须做好日志集中、资源限制、配置外置和监控。
单个容器跑不起来完整项目,Web 服务、数据库、缓存、消息队列往往需要协同工作。Docker Compose 就是为此设计的——它用一个 docker-compose.yml 文件描述多个容器的配置、依赖关系和启动顺序。
比如一个 Flask + PostgreSQL + Redis 的典型组合,docker-compose.yml 可以这样写:
web 服务:基于自建镜像或 Dockerfile 构建,暴露端口,链接数据库和缓存db 服务:使用官方 postgres:15 镜像,挂载数据卷确保持久化cache 服务:使用 redis:7-alpine,设置内存限制和密码depends_on 控制启动顺序(注意:它不等待服务就绪,需在应用层加健康检查或重试逻辑)运行 docker-compose up -d 即可一键拉起整套环境;docker-compose logs -f 实时查看各服务日志,排查问题更直观。
别再用 python:3.11-slim 直接 pip install 所有依赖——镜像体积大、缓存失效频繁、安全风险高。推荐多阶段构建 + requirements 分层:
builder 使用 python:3.11-slim 安装编译型依赖(如 psycopg2-binary、cryptography),并把 requirements.txt 拆成 base.txt(运行时必需)和 dev.txt(仅开发/CI 使用)final 使用更小的 python:3.11-slim-bookworm 基础镜像,只复制上一阶段编译好的包和源码,删掉构建工具和缓存user: 1001:1001)、工作目录(WORKDIR /app)、环境变量(ENV PYTHONDONTWRITEBYTECODE=1)这样构建出的镜像通常比传统方式小 40%~60%,且每次 pip install 只在依赖变更时重建对应层,CI 构建速度明显提升。
GitHub Actions 是轻量又可靠的 CI/CD 方案,适合中小型 Python 项目。一个典型的流水线包含三个阶段:
pip install -e ".[test]" 安装带测试依赖的包,运行 pytest --cov 并上传覆盖率报告到 Codecov 或 GitHub Code Scanning
docker buildx 构建多平台镜像(如 linux/amd64 和 linux/arm64),打上 main、v1.2.0 和 latest 标签,推送到 GitHub Container Registry(GHCR)或私有 Harborv*)时触发,SSH 登录生产服务器,拉取新镜像,执行 docker-compose pull && docker-compose up -d,再调用健康检查接口确认服务就绪关键细节:所有敏感信息(如 SSH 私钥、registry token)都存在 GitHub Secrets 中;用 if: startsWith(github.ref, 'refs/tags/') 精确控制部署时机;避免在 CI 中直接操作生产数据库。
容器不是“扔进去就完事”的黑盒。上线前务必确认以下事项:
json-file 默认驱动,改用 fluentd 或 syslog,把所有容器日志发到 ELK 或 Loki;Python 应用里用 logging.handlers.SysLogHandler 直连docker-compose.yml 中为每个服务设置 mem_limit、cpus,并添加 healthcheck(如 curl -f http://localhost:8000/healthz),让 Docker 自动重启异常容器pydantic-settings 统一加载和校验;避免硬编码或打包进镜像cadvisor + prometheus 采集容器 CPU、内存、网络;Python 应用内嵌 prometheus-client 暴露业务指标(如请求延迟、错误率)这些不是锦上添花,而是保障服务稳定、可排查、可伸缩的底线要求。