Spaces:
Running
Running
File size: 2,248 Bytes
dc71cad | 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 | version: '3.9'
services:
# ββ FastAPI backend ββββββββββββββββββββββββββββββββββββββββββββββββββββββ
api:
build:
context: .
dockerfile: Dockerfile.api
ports:
- "8000:8000"
environment:
- OPENAI_API_KEY=${OPENAI_API_KEY}
- REDIS_URL=redis://redis:6379/0
- CELERY_BROKER_URL=redis://redis:6379/1
- DISKCACHE_DIR=/data/diskcache
- RESULTS_DIR=/data/results
volumes:
- ./results:/data/results
- agent_cache:/data/diskcache
depends_on:
- redis
restart: unless-stopped
healthcheck:
test: ["CMD", "curl", "-f", "http://localhost:8000/api/health"]
interval: 10s
timeout: 5s
retries: 3
# ββ Next.js frontend βββββββββββββββββββββββββββββββββββββββββββββββββββββ
frontend:
build:
context: ./frontend
dockerfile: Dockerfile.frontend
ports:
- "3000:3000"
environment:
- NEXT_PUBLIC_API_URL=http://localhost:8000
- NEXT_PUBLIC_WS_URL=ws://localhost:8000
depends_on:
- api
restart: unless-stopped
# ββ Redis (task queue + pub/sub) βββββββββββββββββββββββββββββββββββββββββ
redis:
image: redis:7-alpine
ports:
- "6379:6379"
volumes:
- redis_data:/data
restart: unless-stopped
healthcheck:
test: ["CMD", "redis-cli", "ping"]
interval: 5s
timeout: 3s
retries: 5
# ββ Sandbox executor βββββββββββββββββββββββββββββββββββββββββββββββββββββ
sandbox:
build:
context: ./sandbox
dockerfile: Dockerfile
network_mode: none
read_only: true
tmpfs:
- /tmp:size=512m
security_opt:
- no-new-privileges:true
cap_drop:
- ALL
mem_limit: 2g
cpus: 2.0
restart: "no" # single-use containers, spawned per task
volumes:
redis_data:
agent_cache:
|