fix: Corrected compose subnet to 172.32.0.0/24, added Qdrant + Ollama services, web on port 8096
- Changed network subnet from 172.24.0.0/24 (used by xpltd_docs) to 172.32.0.0/24 - Added chrysopedia-qdrant (qdrant/qdrant:v1.13.2) with healthcheck - Added chrysopedia-ollama for embedding model (nomic-embed-text) - Web UI exposed on 0.0.0.0:8096 (XPLTD port-suffix convention) - API internal-only (via nginx proxy) - Added HEALTHCHECK to Dockerfile.api - Updated .env.example with FYN DGX LLM endpoint
This commit is contained in:
parent
3b01bd94ab
commit
c295384c6a
3 changed files with 88 additions and 27 deletions
27
.env.example
27
.env.example
|
|
@ -1,37 +1,36 @@
|
||||||
# ─── Chrysopedia Environment Variables ───
|
# ─── Chrysopedia Environment Variables ───
|
||||||
|
# Copy to .env and fill in secrets before docker compose up
|
||||||
|
|
||||||
# PostgreSQL
|
# PostgreSQL
|
||||||
POSTGRES_USER=chrysopedia
|
POSTGRES_USER=chrysopedia
|
||||||
POSTGRES_PASSWORD=changeme
|
POSTGRES_PASSWORD=changeme
|
||||||
POSTGRES_DB=chrysopedia
|
POSTGRES_DB=chrysopedia
|
||||||
DATABASE_URL=postgresql+asyncpg://${POSTGRES_USER}:${POSTGRES_PASSWORD}@chrysopedia-db:5432/${POSTGRES_DB}
|
|
||||||
|
|
||||||
# Redis (Celery broker)
|
# Redis (Celery broker) — container-internal, no secret needed
|
||||||
REDIS_URL=redis://chrysopedia-redis:6379/0
|
REDIS_URL=redis://chrysopedia-redis:6379/0
|
||||||
|
|
||||||
# LLM endpoint (OpenAI-compatible)
|
# LLM endpoint (OpenAI-compatible — OpenWebUI on FYN DGX)
|
||||||
LLM_API_URL=https://friend-openwebui.example.com/api
|
LLM_API_URL=https://chat.forgetyour.name/api/v1
|
||||||
LLM_API_KEY=sk-changeme
|
LLM_API_KEY=sk-changeme
|
||||||
LLM_MODEL=qwen2.5-72b
|
LLM_MODEL=FYN-QWEN35
|
||||||
LLM_FALLBACK_URL=http://localhost:11434/v1
|
LLM_FALLBACK_URL=https://chat.forgetyour.name/api/v1
|
||||||
LLM_FALLBACK_MODEL=qwen2.5:14b-q8_0
|
LLM_FALLBACK_MODEL=fyn-qwen35-chat
|
||||||
|
|
||||||
# Embedding endpoint
|
# Embedding endpoint (Ollama container in the compose stack)
|
||||||
EMBEDDING_API_URL=http://localhost:11434/v1
|
EMBEDDING_API_URL=http://chrysopedia-ollama:11434/v1
|
||||||
EMBEDDING_MODEL=nomic-embed-text
|
EMBEDDING_MODEL=nomic-embed-text
|
||||||
|
|
||||||
# Qdrant
|
# Qdrant (container-internal)
|
||||||
QDRANT_URL=http://qdrant:6333
|
QDRANT_URL=http://chrysopedia-qdrant:6333
|
||||||
QDRANT_COLLECTION=chrysopedia
|
QDRANT_COLLECTION=chrysopedia
|
||||||
|
|
||||||
# Application
|
# Application
|
||||||
APP_ENV=production
|
APP_ENV=production
|
||||||
APP_LOG_LEVEL=info
|
APP_LOG_LEVEL=info
|
||||||
APP_SECRET_KEY=changeme-generate-a-real-secret
|
|
||||||
|
|
||||||
# File storage paths (inside container)
|
# File storage paths (inside container, bind-mounted to /vmPool/r/services/chrysopedia_data)
|
||||||
TRANSCRIPT_STORAGE_PATH=/data/transcripts
|
TRANSCRIPT_STORAGE_PATH=/data/transcripts
|
||||||
VIDEO_METADATA_PATH=/data/video_meta
|
VIDEO_METADATA_PATH=/data/video_meta
|
||||||
|
|
||||||
# Review mode toggle
|
# Review mode toggle (true = moments require admin review before publishing)
|
||||||
REVIEW_MODE=true
|
REVIEW_MODE=true
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,6 @@
|
||||||
# Chrysopedia — Docker Compose
|
# Chrysopedia — Docker Compose
|
||||||
# XPLTD convention: xpltd_chrysopedia project, bind mounts, dedicated bridge
|
# XPLTD convention: xpltd_chrysopedia project, bind mounts, dedicated bridge
|
||||||
|
# Deployed to: /vmPool/r/compose/xpltd_chrysopedia/ (symlinked)
|
||||||
name: xpltd_chrysopedia
|
name: xpltd_chrysopedia
|
||||||
|
|
||||||
services:
|
services:
|
||||||
|
|
@ -23,12 +24,14 @@ services:
|
||||||
interval: 10s
|
interval: 10s
|
||||||
timeout: 5s
|
timeout: 5s
|
||||||
retries: 5
|
retries: 5
|
||||||
|
stop_grace_period: 30s
|
||||||
|
|
||||||
# ── Redis (Celery broker) ──
|
# ── Redis (Celery broker + runtime config) ──
|
||||||
chrysopedia-redis:
|
chrysopedia-redis:
|
||||||
image: redis:7-alpine
|
image: redis:7-alpine
|
||||||
container_name: chrysopedia-redis
|
container_name: chrysopedia-redis
|
||||||
restart: unless-stopped
|
restart: unless-stopped
|
||||||
|
command: redis-server --save 60 1 --loglevel warning
|
||||||
volumes:
|
volumes:
|
||||||
- /vmPool/r/services/chrysopedia_redis:/data
|
- /vmPool/r/services/chrysopedia_redis:/data
|
||||||
networks:
|
networks:
|
||||||
|
|
@ -38,6 +41,41 @@ services:
|
||||||
interval: 10s
|
interval: 10s
|
||||||
timeout: 5s
|
timeout: 5s
|
||||||
retries: 5
|
retries: 5
|
||||||
|
stop_grace_period: 15s
|
||||||
|
|
||||||
|
# ── Qdrant vector database ──
|
||||||
|
chrysopedia-qdrant:
|
||||||
|
image: qdrant/qdrant:v1.13.2
|
||||||
|
container_name: chrysopedia-qdrant
|
||||||
|
restart: unless-stopped
|
||||||
|
volumes:
|
||||||
|
- /vmPool/r/services/chrysopedia_qdrant:/qdrant/storage
|
||||||
|
networks:
|
||||||
|
- chrysopedia
|
||||||
|
healthcheck:
|
||||||
|
test: ["CMD-SHELL", "wget -qO- http://localhost:6333/healthz || exit 1"]
|
||||||
|
interval: 15s
|
||||||
|
timeout: 5s
|
||||||
|
retries: 5
|
||||||
|
start_period: 10s
|
||||||
|
stop_grace_period: 30s
|
||||||
|
|
||||||
|
# ── Ollama (embedding model server) ──
|
||||||
|
chrysopedia-ollama:
|
||||||
|
image: ollama/ollama:latest
|
||||||
|
container_name: chrysopedia-ollama
|
||||||
|
restart: unless-stopped
|
||||||
|
volumes:
|
||||||
|
- /vmPool/r/services/chrysopedia_ollama:/root/.ollama
|
||||||
|
networks:
|
||||||
|
- chrysopedia
|
||||||
|
healthcheck:
|
||||||
|
test: ["CMD-SHELL", "curl -sf http://localhost:11434/api/tags || exit 1"]
|
||||||
|
interval: 15s
|
||||||
|
timeout: 5s
|
||||||
|
retries: 5
|
||||||
|
start_period: 30s
|
||||||
|
stop_grace_period: 15s
|
||||||
|
|
||||||
# ── FastAPI application ──
|
# ── FastAPI application ──
|
||||||
chrysopedia-api:
|
chrysopedia-api:
|
||||||
|
|
@ -50,22 +88,27 @@ services:
|
||||||
- path: .env
|
- path: .env
|
||||||
required: false
|
required: false
|
||||||
environment:
|
environment:
|
||||||
DATABASE_URL: postgresql+asyncpg://${POSTGRES_USER:-chrysopedia}:${POSTGRES_PASSWORD}@chrysopedia-db:5432/${POSTGRES_DB:-chrysopedia}
|
DATABASE_URL: postgresql+asyncpg://${POSTGRES_USER:-chrysopedia}:${POSTGRES_PASSWORD:-changeme}@chrysopedia-db:5432/${POSTGRES_DB:-chrysopedia}
|
||||||
REDIS_URL: redis://chrysopedia-redis:6379/0
|
REDIS_URL: redis://chrysopedia-redis:6379/0
|
||||||
|
QDRANT_URL: http://chrysopedia-qdrant:6333
|
||||||
|
EMBEDDING_API_URL: http://chrysopedia-ollama:11434/v1
|
||||||
volumes:
|
volumes:
|
||||||
- ./backend:/app
|
|
||||||
- /vmPool/r/services/chrysopedia_data:/data
|
- /vmPool/r/services/chrysopedia_data:/data
|
||||||
ports:
|
- ./config:/config:ro
|
||||||
- "127.0.0.1:8000:8000"
|
|
||||||
depends_on:
|
depends_on:
|
||||||
chrysopedia-db:
|
chrysopedia-db:
|
||||||
condition: service_healthy
|
condition: service_healthy
|
||||||
chrysopedia-redis:
|
chrysopedia-redis:
|
||||||
condition: service_healthy
|
condition: service_healthy
|
||||||
|
chrysopedia-qdrant:
|
||||||
|
condition: service_healthy
|
||||||
|
chrysopedia-ollama:
|
||||||
|
condition: service_healthy
|
||||||
networks:
|
networks:
|
||||||
- chrysopedia
|
- chrysopedia
|
||||||
|
stop_grace_period: 15s
|
||||||
|
|
||||||
# ── Celery worker (pipeline stages 2-5) ──
|
# ── Celery worker (pipeline stages 2-6) ──
|
||||||
chrysopedia-worker:
|
chrysopedia-worker:
|
||||||
build:
|
build:
|
||||||
context: .
|
context: .
|
||||||
|
|
@ -76,38 +119,52 @@ services:
|
||||||
- path: .env
|
- path: .env
|
||||||
required: false
|
required: false
|
||||||
environment:
|
environment:
|
||||||
DATABASE_URL: postgresql+asyncpg://${POSTGRES_USER:-chrysopedia}:${POSTGRES_PASSWORD}@chrysopedia-db:5432/${POSTGRES_DB:-chrysopedia}
|
DATABASE_URL: postgresql+asyncpg://${POSTGRES_USER:-chrysopedia}:${POSTGRES_PASSWORD:-changeme}@chrysopedia-db:5432/${POSTGRES_DB:-chrysopedia}
|
||||||
REDIS_URL: redis://chrysopedia-redis:6379/0
|
REDIS_URL: redis://chrysopedia-redis:6379/0
|
||||||
command: ["celery", "-A", "worker", "worker", "--loglevel=info"]
|
QDRANT_URL: http://chrysopedia-qdrant:6333
|
||||||
|
EMBEDDING_API_URL: http://chrysopedia-ollama:11434/v1
|
||||||
|
command: ["celery", "-A", "worker", "worker", "--loglevel=info", "--concurrency=2"]
|
||||||
volumes:
|
volumes:
|
||||||
- ./backend:/app
|
|
||||||
- /vmPool/r/services/chrysopedia_data:/data
|
- /vmPool/r/services/chrysopedia_data:/data
|
||||||
- ./prompts:/prompts:ro
|
- ./prompts:/prompts:ro
|
||||||
|
- ./config:/config:ro
|
||||||
depends_on:
|
depends_on:
|
||||||
chrysopedia-db:
|
chrysopedia-db:
|
||||||
condition: service_healthy
|
condition: service_healthy
|
||||||
chrysopedia-redis:
|
chrysopedia-redis:
|
||||||
condition: service_healthy
|
condition: service_healthy
|
||||||
|
chrysopedia-qdrant:
|
||||||
|
condition: service_healthy
|
||||||
|
chrysopedia-ollama:
|
||||||
|
condition: service_healthy
|
||||||
networks:
|
networks:
|
||||||
- chrysopedia
|
- chrysopedia
|
||||||
|
stop_grace_period: 30s
|
||||||
|
|
||||||
# ── React web UI (nginx) ──
|
# ── React web UI (nginx) ──
|
||||||
chrysopedia-web:
|
chrysopedia-web:
|
||||||
build:
|
build:
|
||||||
context: .
|
context: .
|
||||||
dockerfile: docker/Dockerfile.web
|
dockerfile: docker/Dockerfile.web
|
||||||
container_name: chrysopedia-web
|
container_name: chrysopedia-web-8096
|
||||||
restart: unless-stopped
|
restart: unless-stopped
|
||||||
ports:
|
ports:
|
||||||
- "127.0.0.1:3000:80"
|
- "0.0.0.0:8096:80"
|
||||||
depends_on:
|
depends_on:
|
||||||
- chrysopedia-api
|
- chrysopedia-api
|
||||||
networks:
|
networks:
|
||||||
- chrysopedia
|
- chrysopedia
|
||||||
|
healthcheck:
|
||||||
|
test: ["CMD-SHELL", "wget -qO- http://localhost:80/ || exit 1"]
|
||||||
|
interval: 30s
|
||||||
|
timeout: 5s
|
||||||
|
retries: 3
|
||||||
|
start_period: 10s
|
||||||
|
stop_grace_period: 15s
|
||||||
|
|
||||||
networks:
|
networks:
|
||||||
chrysopedia:
|
chrysopedia:
|
||||||
driver: bridge
|
driver: bridge
|
||||||
ipam:
|
ipam:
|
||||||
config:
|
config:
|
||||||
- subnet: 172.24.0.0/24
|
- subnet: "172.32.0.0/24"
|
||||||
|
|
|
||||||
|
|
@ -4,7 +4,7 @@ WORKDIR /app
|
||||||
|
|
||||||
# System deps
|
# System deps
|
||||||
RUN apt-get update && apt-get install -y --no-install-recommends \
|
RUN apt-get update && apt-get install -y --no-install-recommends \
|
||||||
gcc libpq-dev \
|
gcc libpq-dev curl \
|
||||||
&& rm -rf /var/lib/apt/lists/*
|
&& rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
# Python deps (cached layer)
|
# Python deps (cached layer)
|
||||||
|
|
@ -13,7 +13,12 @@ RUN pip install --no-cache-dir -r requirements.txt
|
||||||
|
|
||||||
# Application code
|
# Application code
|
||||||
COPY backend/ /app/
|
COPY backend/ /app/
|
||||||
|
COPY prompts/ /prompts/
|
||||||
|
COPY config/ /config/
|
||||||
|
|
||||||
EXPOSE 8000
|
EXPOSE 8000
|
||||||
|
|
||||||
|
HEALTHCHECK --interval=15s --timeout=5s --retries=3 --start-period=10s \
|
||||||
|
CMD curl -f http://localhost:8000/health || exit 1
|
||||||
|
|
||||||
CMD ["uvicorn", "main:app", "--host", "0.0.0.0", "--port", "8000"]
|
CMD ["uvicorn", "main:app", "--host", "0.0.0.0", "--port", "8000"]
|
||||||
|
|
|
||||||
Loading…
Add table
Reference in a new issue