Spaces:
Sleeping
Sleeping
File size: 2,381 Bytes
dbced4f | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 | version: '3.9'
services:
# ββ Redis (message broker + result backend) ββββββββββββββββββββββββββββββ
redis:
image: redis:7-alpine
container_name: seg_redis
ports:
- "6379:6379"
volumes:
- redis_data:/data
healthcheck:
test: ["CMD", "redis-cli", "ping"]
interval: 5s
timeout: 3s
retries: 10
restart: unless-stopped
# ββ FastAPI Backend βββββββββββββββββββββββββββββββββββββββββββββββββββββββ
backend:
build:
context: ./backend
dockerfile: Dockerfile
container_name: seg_backend
ports:
- "8000:8000"
environment:
- REDIS_URL=redis://redis:6379/0
- UPLOAD_DIR=/data/uploads
- OUTPUT_DIR=/data/outputs
- MAX_FILE_SIZE_MB=200
volumes:
- seg_data:/data
- ./backend:/app # hot-reload in dev
depends_on:
redis:
condition: service_healthy
command: uvicorn main:app --host 0.0.0.0 --port 8000 --reload
restart: unless-stopped
# ββ Celery Worker βββββββββββββββββββββββββββββββββββββββββββββββββββββββββ
worker:
build:
context: ./backend
dockerfile: Dockerfile
container_name: seg_worker
environment:
- REDIS_URL=redis://redis:6379/0
- UPLOAD_DIR=/data/uploads
- OUTPUT_DIR=/data/outputs
volumes:
- seg_data:/data
- ./backend:/app
depends_on:
redis:
condition: service_healthy
# 2 concurrent workers; adjust --concurrency for more GPU jobs
command: celery -A tasks worker --loglevel=info --concurrency=2
restart: unless-stopped
# ββ Next.js Frontend βββββββββββββββββββββββββββββββββββββββββββββββββββββ
frontend:
build:
context: ./frontend
dockerfile: Dockerfile
container_name: seg_frontend
ports:
- "3000:3000"
environment:
- NEXT_PUBLIC_API_URL=http://localhost:8000
depends_on:
- backend
restart: unless-stopped
volumes:
redis_data:
seg_data:
|