Hermes / Dockerfile
GitHub Action
Auto deploy from GitHub 2026-05-10 16:32:58
bf076b8
FROM python:3.11-slim
LABEL maintainer="Hermes Agent Community"
LABEL version="0.10.0"
LABEL description="Hermes Agent v0.10.0 with Web UI on Hugging Face Spaces"
# ==================== 环境变量 ====================
ENV PYTHONUNBUFFERED=1
ENV DEBIAN_FRONTEND=noninteractive
ENV HERMES_HOME=/data/.hermes
ENV PYTHONPATH=/app
# BFF Server 环境变量(构建阶段)
ENV PORT=7860
ENV UPSTREAM=http://127.0.0.1:8642
ENV HERMES_BIN=/usr/local/bin/hermes
# 注意:NODE_ENV=production 不能在此设置!
# npm install 在 NODE_ENV=production 时会跳过 devDependencies,
# 导致 vue-tsc 等构建工具缺失。NODE_ENV 在运行时阶段再设置。
# ==================== 系统依赖 ====================
RUN apt-get update && apt-get install -y \
build-essential \
ffmpeg \
git \
curl \
unzip \
ca-certificates \
&& rm -rf /var/lib/apt/lists/*
# ==================== Node.js v23 ====================
# hermes-web-ui 要求 Node >= 23.0.0
RUN ARCH=$(dpkg --print-architecture) \
&& if [ "$ARCH" = "amd64" ]; then NODE_ARCH="x64"; else NODE_ARCH="$ARCH"; fi \
&& echo "Installing Node.js v23.11.0 for ${NODE_ARCH}" \
&& curl -fsSL "https://nodejs.org/dist/v23.11.0/node-v23.11.0-linux-${NODE_ARCH}.tar.gz" \
-o /tmp/node.tar.gz \
&& tar -xzf /tmp/node.tar.gz -C /usr/local --strip-components=1 \
&& rm -f /tmp/node.tar.gz \
&& node --version \
&& npm --version
# ==================== Bun Runtime ====================
# baoyu-skills 需要 bun 运行时
# 安装到 /usr/local/bin 以便所有用户(包括 appuser)都能访问
RUN echo "Installing Bun runtime" \
&& curl -fsSL https://bun.sh/install | bash \
&& export PATH="$PATH:/root/.bun/bin" \
&& bun --version \
&& cp /root/.bun/bin/bun /usr/local/bin/bun \
&& chmod +x /usr/local/bin/bun
# bun 必须在运行时 PATH 中可用(agent 子进程通过 bun 调用 baoyu-skills)
# /usr/local/bin 已在默认 PATH 中,所有用户均可访问
# ==================== baoyu-skills 脚本预置 ====================
# 将完整的 baoyu-imagine 脚本预置到 ~/.baoyu-skills/ 目录
# 此目录是 main.ts loadExtendConfig() 的查找路径之一
# 避免依赖 Web UI 技能安装(可能只下载编译产物而丢失 .ts 源文件)
RUN mkdir -p /home/appuser/.baoyu-skills/baoyu-imagine && \
git clone --depth 1 https://github.com/JimLiu/baoyu-skills.git /tmp/baoyu-skills && \
cp -r /tmp/baoyu-skills/skills/baoyu-imagine/scripts \
/home/appuser/.baoyu-skills/baoyu-imagine/scripts && \
rm -rf /tmp/baoyu-skills
# ==================== 工具安装 ====================
# yq: 运行时修改 config.yaml
RUN curl -sL https://github.com/mikefarah/yq/releases/latest/download/yq_linux_amd64 -o /usr/bin/yq && \
chmod +x /usr/bin/yq
# ==================== Python 依赖 ====================
COPY requirements.txt /tmp/
RUN pip install --no-cache-dir -r /tmp/requirements.txt
# ==================== Hermes Agent ====================
# 克隆并安装 Hermes Agent(不再构建内置 Dashboard 前端,由 hermes-web-ui 替代)
RUN git clone --depth 1 https://github.com/NousResearch/hermes-agent.git /tmp/hermes-agent && \
pip install --no-cache-dir /tmp/hermes-agent[all] && \
rm -rf /tmp/hermes-agent /root/.cache/pip
# Playwright 浏览器(Hermes Agent 工具调用需要)
RUN npx playwright install chromium --with-deps --only-shell
# ==================== Hermes Web UI ====================
# 克隆、构建、精简 hermes-web-ui(单层,避免中间态占用空间)
RUN git clone --depth 1 https://github.com/EKKOLearnAI/hermes-web-ui.git /tmp/hermes-web-ui && \
cd /tmp/hermes-web-ui && \
npm pkg delete scripts.prepare && \
npm install && \
npm run build && \
npm prune --omit=dev && \
mkdir -p /opt/hermes-web-ui && \
cp -r dist node_modules package.json /opt/hermes-web-ui/ && \
rm -rf /tmp/hermes-web-ui /root/.npm
# ==================== 应用代码 ====================
WORKDIR /app
COPY src/ /app/src/
COPY entrypoint.sh /app/
COPY image-proxy.js /app/
COPY image-gen-siliconflow.ts /app/
COPY config/config.yaml /data/.hermes/config.yaml
# 创建数据目录
RUN mkdir -p /data/.hermes /data/.hermes-web-ui /app/logs /home/appuser/.hermes-web-ui/logs && \
chmod +x /app/entrypoint.sh
# 设置非 root 用户(Hugging Face Spaces 要求)
RUN useradd -m -u 1000 appuser && \
ln -sf /data/.hermes /home/appuser/.hermes && \
mkdir -p /home/appuser/.cache && \
chown -R appuser:appuser /data /opt/hermes-web-ui /app /home/appuser
USER appuser
# ==================== 运行时环境变量 ====================
# 构建阶段不设 NODE_ENV=production(会导致 npm install 跳过 devDependencies)
# 此处设置,仅影响运行时行为
ENV NODE_ENV=production
# 7860: BFF Server (Web UI 入口,HF Spaces 要求)
# 8642: Gateway API Server (BFF 的上游代理目标,仅容器内部)
EXPOSE 7860
HEALTHCHECK --interval=30s --timeout=10s --start-period=90s --retries=3 \
CMD curl -f http://localhost:7860/health || exit 1
ENTRYPOINT ["/app/entrypoint.sh"]