Spaces:
Running
Running
| # 使用Python 3.11作为基础镜像 | |
| FROM python:3.11-slim | |
| # 设置工作目录 | |
| WORKDIR /app | |
| ENV PYTHONDONTWRITEBYTECODE=1 | |
| ENV PYTHONUNBUFFERED=1 | |
| # 安装依赖,包括 git 和 redis-server | |
| RUN apt-get update && apt-get install -y --no-install-recommends \ | |
| git \ | |
| redis-server \ | |
| && apt-get clean \ | |
| && rm -rf /var/lib/apt/lists/* | |
| # 复制并安装 Python 依赖 | |
| COPY requirements.txt . | |
| RUN pip install --no-cache-dir -r requirements.txt | |
| # 复制应用代码和启动脚本 | |
| COPY . . | |
| COPY start.sh . | |
| RUN chmod +x start.sh # 赋予脚本执行权限 | |
| # 创建非 root 用户,并赋予 /app 目录和脚本权限 | |
| RUN adduser --disabled-password --gecos "" appuser \ | |
| && chown -R appuser:appuser /app \ | |
| && chown appuser:appuser start.sh | |
| # 切换到非 root 用户 | |
| USER appuser | |
| # 暴露端口 | |
| EXPOSE 7860 | |
| # 使用启动脚本启动 Redis 和 Python 应用 | |
| CMD ["./start.sh"] | |