Files
agenticSystem/Dockerfile
Jordan 037bc81936 Reportar modelo real en no-streaming + prewarm de mcp-server-fetch
- engine.py: process_message ahora incluye model/modelUsage en el dict de
  retorno (no solo en el evento SSE), para que el camino no-streaming
  (cronjobs -> _report_usage) reporte el modelo real a consumo_acaicode en
  vez de "unknown".
- Dockerfile: precalentar `uvx mcp-server-fetch` en build (como appuser) para
  que la cache de uv quede en la imagen y el MCP fetch no se quede sin arrancar
  por timeout en frio tras un rebuild.
- mcp.json: startup_timeout de fetch 15 -> 30s como margen.

Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
2026-06-22 13:20:51 +01:00

69 lines
2.5 KiB
Docker

FROM python:3.12-slim AS base
WORKDIR /app
# Instalar dependencias de sistema + Node.js 20
RUN apt-get update && apt-get install -y --no-install-recommends \
build-essential \
curl \
ca-certificates \
gnupg \
git \
&& mkdir -p /etc/apt/keyrings \
&& curl -fsSL https://deb.nodesource.com/gpgkey/nodesource-repo.gpg.key \
| gpg --dearmor -o /etc/apt/keyrings/nodesource.gpg \
&& echo "deb [signed-by=/etc/apt/keyrings/nodesource.gpg] https://deb.nodesource.com/node_20.x nodistro main" \
> /etc/apt/sources.list.d/nodesource.list \
&& apt-get update \
&& apt-get install -y --no-install-recommends nodejs \
&& rm -rf /var/lib/apt/lists/*
# Instalar dependencias Python
COPY agenticSystem/requirements.txt .
RUN pip install --no-cache-dir -r requirements.txt
# Instalar dependencias del MCP server (Node)
COPY agenticSystem/mcp-server/package.json agenticSystem/mcp-server/package-lock.json* ./mcp-server/
RUN cd mcp-server && npm install --production
# Instalar dependencias de sistema de Playwright (como root)
RUN cd mcp-server && npx playwright install-deps chromium
# Instalar uv (incluye uvx) para mcp-server-fetch
RUN pip install --no-cache-dir uv
# Copiar codigo fuente del MCP server
COPY agenticSystem/mcp-server/ ./mcp-server/
# Copiar codigo fuente Python
COPY agenticSystem/src/ ./src/
# Copiar configuracion MCP, documentacion y agentes
COPY agenticSystem/mcp.json ./mcp.json
COPY agenticSystem/docs/ ./docs/
COPY agenticSystem/agents/ ./agents/
# Crear directorio para mount point de webs
RUN mkdir -p /opt/acai/webs
# Usuario no-root — UID 1001 para coincidir con el usuario 'acai' del container app
# Así los archivos creados por el MCP server son escribibles por ambos containers
RUN useradd -m -u 1001 appuser \
&& chown -R appuser:appuser /app \
&& chown -R appuser:appuser /opt/acai/webs
USER appuser
# Descargar Chromium como appuser (queda en ~/.cache/ms-playwright/)
RUN cd mcp-server && npx playwright install chromium
# Precalentar mcp-server-fetch como appuser: uvx descarga ~43 paquetes la
# primera vez, lo que en frio supera el startup_timeout del MCP. Lo dejamos
# cacheado en ~/.cache/uv dentro de la imagen para que arranque rapido en
# runtime (igual que Chromium). El server lee stdin; con </dev/null sale tras
# instalar. `|| true` para no romper el build si sale != 0.
RUN timeout 180 uvx mcp-server-fetch </dev/null >/dev/null 2>&1 || true
EXPOSE 8000
CMD ["uvicorn", "src.main:app", "--host", "0.0.0.0", "--port", "8000"]