# syntax=docker/dockerfile:1 # 使用 Python 3.12 slim 镜像 FROM python:3.12-slim ENV TZ=Asia/Shanghai ENV ENV=pro ENV PYTHONDONTWRITEBYTECODE=1 ENV PYTHONUNBUFFERED=1 # 时区 + 系统依赖 RUN ln -sf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone \ && rm -rf /etc/apt/sources.list.d/* \ && echo "deb https://mirrors.aliyun.com/debian/ bookworm main non-free contrib" > /etc/apt/sources.list \ && echo "deb https://mirrors.aliyun.com/debian-security/ bookworm-security main non-free contrib" >> /etc/apt/sources.list \ && echo "deb https://mirrors.aliyun.com/debian/ bookworm-updates main non-free contrib" >> /etc/apt/sources.list \ && apt-get clean \ && apt-get update \ && apt-get install -y --no-install-recommends curl \ && rm -rf /var/lib/apt/lists/* RUN mkdir -p /app/app/logs WORKDIR /app # 先拷贝依赖声明,利用 Docker 层缓存 COPY requirements.txt . RUN pip install --no-cache-dir -r requirements.txt \ -i https://mirrors.aliyun.com/pypi/simple/ \ --trusted-host mirrors.aliyun.com # 拷贝应用代码和环境配置 COPY app/ ./app/ COPY .env.prod ./.env.prod EXPOSE 8000 HEALTHCHECK --interval=30s --timeout=5s --start-period=20s --retries=3 \ CMD curl -sf http://localhost:8000/health/ || exit 1 # Gunicorn + Uvicorn Worker CMD ["gunicorn", "-w", "2", "-k", "uvicorn.workers.UvicornWorker", \ "app.main:app", "-b", "0.0.0.0:8000", \ "--timeout", "120", "--graceful-timeout", "30", \ "--access-logfile", "-"]