55 lines
1.4 KiB
Docker
55 lines
1.4 KiB
Docker
# syntax=docker/dockerfile:1.9
|
|
FROM python:3.12-slim
|
|
|
|
WORKDIR /app
|
|
|
|
# Install system dependencies
|
|
RUN apt-get update && apt-get install -y --no-install-recommends \
|
|
curl \
|
|
ca-certificates \
|
|
&& rm -rf /var/lib/apt/lists/*
|
|
|
|
# Install uv using the installer script
|
|
ADD https://astral.sh/uv/install.sh /uv-installer.sh
|
|
RUN sh /uv-installer.sh && rm /uv-installer.sh
|
|
|
|
# Add uv to PATH
|
|
ENV PATH="/root/.local/bin:${PATH}"
|
|
|
|
# Configure uv for optimal Docker usage
|
|
ENV UV_COMPILE_BYTECODE=1 \
|
|
UV_LINK_MODE=copy \
|
|
UV_PYTHON_DOWNLOADS=never \
|
|
MCP_SERVER_HOST="0.0.0.0" \
|
|
PYTHONUNBUFFERED=1
|
|
|
|
# Create non-root user
|
|
RUN groupadd -r app && useradd -r -d /app -g app app
|
|
|
|
# Copy project files for dependency installation (better caching)
|
|
COPY pyproject.toml uv.lock ./
|
|
|
|
# Remove the local path override for graphiti-core in Docker builds
|
|
# This allows uv to use the published package from PyPI
|
|
RUN sed -i '/\[tool\.uv\.sources\]/,/graphiti-core/d' pyproject.toml
|
|
|
|
# Install dependencies first (better layer caching)
|
|
RUN --mount=type=cache,target=/root/.cache/uv \
|
|
uv sync --no-dev
|
|
|
|
# Copy application code and configuration
|
|
COPY main.py ./
|
|
COPY src/ ./src/
|
|
COPY config/ ./config/
|
|
|
|
# Set execute permissions on main.py and change ownership to app user
|
|
RUN chmod +x /app/main.py && chown -Rv app:app /app
|
|
|
|
# Switch to non-root user
|
|
USER app
|
|
|
|
# Expose port
|
|
EXPOSE 8000
|
|
|
|
# Command to run the application
|
|
CMD ["uv", "run", "main.py"]
|