- FastAPI + NiceGUI web application - QuantLib-based Black-Scholes pricing with Greeks - Protective put, laddered, and LEAPS strategies - Real-time WebSocket updates - TradingView-style charts via Lightweight-Charts - Docker containerization - GitLab CI/CD pipeline for VPS deployment - VPN-only access configuration
53 lines
1.4 KiB
Docker
53 lines
1.4 KiB
Docker
# syntax=docker/dockerfile:1.7
|
|
|
|
FROM python:3.11-slim AS builder
|
|
|
|
ENV PYTHONDONTWRITEBYTECODE=1 \
|
|
PYTHONUNBUFFERED=1 \
|
|
PIP_NO_CACHE_DIR=1 \
|
|
PIP_DISABLE_PIP_VERSION_CHECK=1 \
|
|
VIRTUAL_ENV=/opt/venv
|
|
|
|
WORKDIR /app
|
|
|
|
RUN apt-get update \
|
|
&& apt-get install --no-install-recommends -y build-essential \
|
|
&& rm -rf /var/lib/apt/lists/* \
|
|
&& python -m venv "$VIRTUAL_ENV"
|
|
|
|
ENV PATH="$VIRTUAL_ENV/bin:$PATH"
|
|
|
|
COPY requirements.txt ./
|
|
RUN pip install --upgrade pip setuptools wheel \
|
|
&& pip install -r requirements.txt
|
|
|
|
FROM python:3.11-slim AS runtime
|
|
|
|
ENV PYTHONDONTWRITEBYTECODE=1 \
|
|
PYTHONUNBUFFERED=1 \
|
|
VIRTUAL_ENV=/opt/venv \
|
|
PATH="/opt/venv/bin:$PATH"
|
|
|
|
WORKDIR /app
|
|
|
|
RUN groupadd --system appuser \
|
|
&& useradd --system --gid appuser --create-home --home-dir /home/appuser appuser \
|
|
&& mkdir -p /app/data/cache /app/data/exports \
|
|
&& chown -R appuser:appuser /app /home/appuser
|
|
|
|
COPY --from=builder /opt/venv /opt/venv
|
|
COPY --chown=appuser:appuser app ./app
|
|
COPY --chown=appuser:appuser config ./config
|
|
COPY --chown=appuser:appuser scripts/entrypoint.sh ./scripts/entrypoint.sh
|
|
|
|
RUN chmod +x /app/scripts/entrypoint.sh
|
|
|
|
USER appuser
|
|
|
|
EXPOSE 8000
|
|
|
|
HEALTHCHECK --interval=30s --timeout=5s --start-period=20s --retries=3 \
|
|
CMD python -c "import sys, urllib.request; urllib.request.urlopen('http://127.0.0.1:8000/health', timeout=3); sys.exit(0)"
|
|
|
|
ENTRYPOINT ["/app/scripts/entrypoint.sh"]
|