Spaces:
Running
Running
# Dockerfile - 修复缓存权限 | |
FROM python:3.11-slim | |
# 设置工作目录 | |
WORKDIR /app | |
# 设置环境变量 | |
ENV PYTHONPATH=/app | |
ENV PYTHONUNBUFFERED=1 | |
ENV PIP_NO_CACHE_DIR=1 | |
ENV HF_HOME=/app/.cache/huggingface | |
ENV TRANSFORMERS_CACHE=/app/.cache/huggingface | |
ENV HF_DATASETS_CACHE=/app/.cache/huggingface | |
# 安装系统依赖 | |
RUN apt-get update && apt-get install -y \ | |
git \ | |
curl \ | |
build-essential \ | |
&& rm -rf /var/lib/apt/lists/* | |
# 创建缓存目录并设置权限 | |
RUN mkdir -p /app/.cache/huggingface && \ | |
chmod 755 /app/.cache && \ | |
chmod 755 /app/.cache/huggingface | |
# 升级 pip 到最新版本 | |
RUN pip install --upgrade pip | |
# 复制requirements文件并安装Python依赖 | |
COPY requirements.txt . | |
RUN pip install --no-cache-dir -r requirements.txt | |
# 复制项目文件 | |
COPY . . | |
# ==================== 新增指令开始 ==================== | |
# 创建一个非 root 用户来运行应用,增加安全性 | |
RUN useradd --create-home --shell /bin/bash appuser | |
# 预先创建 huggingface 的缓存目录,并把整个 /app 目录的所有权 | |
# 递归地(-R)交给 appuser 用户 | |
RUN mkdir -p /app/.cache/huggingface && chown -R appuser:appuser /app | |
# 切换到 appuser 用户来执行后续的命令 | |
USER appuser | |
# ==================== 新增指令结束 ==================== | |
# 在构建时进行HF认证(如果token可用) | |
ARG Assitant_tocken | |
RUN if [ -n "$Assitant_tocken" ]; then \ | |
export HF_HOME=/app/.cache/huggingface && \ | |
python -c "from huggingface_hub import login; login('$Assitant_tocken', add_to_git_credential=False)"; \ | |
fi | |
# 暴露端口 | |
EXPOSE 7860 | |
# 健康检查 | |
HEALTHCHECK --interval=30s --timeout=30s --start-period=120s --retries=3 \ | |
CMD curl -f http://localhost:7860/health || exit 1 | |
# 启动命令 | |
CMD ["python", "-m", "uvicorn", "app:app", "--host", "0.0.0.0", "--port", "7860"] |