- 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>
69 lines
2.5 KiB
Docker
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"]
|