suna/backend/docker-compose.yml

103 lines
2.3 KiB
YAML

services:
api:
image: ghcr.io/suna-ai/suna-backend:latest
platform: linux/amd64
build:
context: .
dockerfile: Dockerfile
ports:
- "8000:8000"
env_file:
- .env
volumes:
- .:/app
- /app/.venv
- ./logs:/app/logs
restart: unless-stopped
depends_on:
redis:
condition: service_healthy
networks:
- app-network
environment:
- REDIS_HOST=redis
- REDIS_PORT=6379
- REDIS_PASSWORD=
- LOG_LEVEL=INFO
logging:
driver: "json-file"
options:
max-size: "10m"
max-file: "3"
healthcheck:
test: ["CMD", "curl", "-f", "http://localhost:8000/api/health"]
interval: 30s
timeout: 10s
retries: 3
start_period: 40s
worker:
image: ghcr.io/suna-ai/suna-backend:latest
platform: linux/amd64
build:
context: .
dockerfile: Dockerfile
command: uv run dramatiq --skip-logging --processes 4 --threads 4 run_agent_background
env_file:
- .env
volumes:
- .:/app
- /app/.venv
- ./worker-logs:/app/logs
restart: unless-stopped
depends_on:
redis:
condition: service_healthy
networks:
- app-network
environment:
- REDIS_HOST=redis
- REDIS_PORT=6379
- REDIS_PASSWORD=
- LOG_LEVEL=INFO
logging:
driver: "json-file"
options:
max-size: "10m"
max-file: "3"
healthcheck:
test: ["CMD", "uv", "run", "worker_health.py"]
timeout: 20s
interval: 30s
start_period: 40s
redis:
image: redis:8-alpine
ports:
- "127.0.0.1:6379:6379"
volumes:
- redis_data:/data
- ./services/docker/redis.conf:/usr/local/etc/redis/redis.conf:ro
restart: unless-stopped
networks:
- app-network
command: redis-server /usr/local/etc/redis/redis.conf --appendonly yes --bind 0.0.0.0 --protected-mode no --maxmemory 8gb --maxmemory-policy allkeys-lru
healthcheck:
test: ["CMD", "redis-cli", "ping"]
interval: 10s
timeout: 5s
retries: 5
start_period: 10s
logging:
driver: "json-file"
options:
max-size: "10m"
max-file: "3"
networks:
app-network:
driver: bridge
volumes:
redis_data: