|
|
|
|
|
|
|
FROM python:3.10-slim as base |
|
|
|
|
|
ENV PYTHONUNBUFFERED=1 \ |
|
PYTHONDONTWRITEBYTECODE=1 \ |
|
PIP_NO_CACHE_DIR=1 \ |
|
PIP_DISABLE_PIP_VERSION_CHECK=1 |
|
|
|
|
|
RUN apt-get update && apt-get install -y \ |
|
git \ |
|
curl \ |
|
wget \ |
|
build-essential \ |
|
&& rm -rf /var/lib/apt/lists/* |
|
|
|
|
|
RUN useradd --create-home --shell /bin/bash cyberllm |
|
USER cyberllm |
|
WORKDIR /home/cyberllm |
|
|
|
|
|
COPY --chown=cyberllm:cyberllm requirements.txt . |
|
|
|
|
|
RUN pip install --user --no-cache-dir -r requirements.txt |
|
|
|
|
|
FROM base as development |
|
|
|
|
|
RUN pip install --user --no-cache-dir \ |
|
pytest \ |
|
pytest-cov \ |
|
black \ |
|
flake8 \ |
|
mypy \ |
|
jupyter |
|
|
|
|
|
COPY --chown=cyberllm:cyberllm . . |
|
|
|
|
|
ENV PYTHONPATH=/home/cyberllm:$PYTHONPATH |
|
|
|
EXPOSE 8000 |
|
|
|
CMD ["python", "-m", "uvicorn", "src.deployment.api:app", "--host", "0.0.0.0", "--port", "8000"] |
|
|
|
|
|
FROM base as production |
|
|
|
|
|
COPY --chown=cyberllm:cyberllm src/ ./src/ |
|
COPY --chown=cyberllm:cyberllm configs/ ./configs/ |
|
COPY --chown=cyberllm:cyberllm adapters/ ./adapters/ |
|
COPY --chown=cyberllm:cyberllm scripts/ ./scripts/ |
|
|
|
|
|
ENV PYTHONPATH=/home/cyberllm:$PYTHONPATH |
|
|
|
|
|
RUN mkdir -p data/raw data/processed logs models |
|
|
|
|
|
HEALTHCHECK --interval=30s --timeout=30s --start-period=5s --retries=3 \ |
|
CMD curl -f http://localhost:8000/health || exit 1 |
|
|
|
EXPOSE 8000 |
|
|
|
CMD ["python", "-m", "uvicorn", "src.deployment.api:app", "--host", "0.0.0.0", "--port", "8000", "--workers", "4"] |
|
|
|
|
|
FROM base as cli |
|
|
|
COPY --chown=cyberllm:cyberllm src/ ./src/ |
|
COPY --chown=cyberllm:cyberllm configs/ ./configs/ |
|
COPY --chown=cyberllm:cyberllm scripts/ ./scripts/ |
|
|
|
|
|
ENV PYTHONPATH=/home/cyberllm:$PYTHONPATH |
|
|
|
|
|
RUN chmod +x scripts/*.py |
|
|
|
ENTRYPOINT ["python", "src/deployment/cli/cyber_cli.py"] |
|
|
|
|
|
FROM base as training |
|
|
|
|
|
RUN pip install --user --no-cache-dir \ |
|
accelerate \ |
|
deepspeed \ |
|
wandb |
|
|
|
COPY --chown=cyberllm:cyberllm . . |
|
|
|
|
|
ENV PYTHONPATH=/home/cyberllm:$PYTHONPATH |
|
|
|
|
|
RUN mkdir -p models/checkpoints logs/training data/processed |
|
|
|
CMD ["python", "src/training/train.py"] |
|
|