Files
hive/docker-compose.yml
anthonyrawlins d7ad321176 Initial commit: Complete Hive distributed AI orchestration platform
This comprehensive implementation includes:
- FastAPI backend with MCP server integration
- React/TypeScript frontend with Vite
- PostgreSQL database with Redis caching
- Grafana/Prometheus monitoring stack
- Docker Compose orchestration
- Full MCP protocol support for Claude Code integration

Features:
- Agent discovery and management across network
- Visual workflow editor and execution engine
- Real-time task coordination and monitoring
- Multi-model support with specialized agents
- Distributed development task allocation

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-07-07 21:44:31 +10:00

115 lines
2.7 KiB
YAML

version: '3.8'
services:
# Hive Backend API
hive-backend:
build:
context: ./backend
dockerfile: Dockerfile
ports:
- "8087:8000"
environment:
- DATABASE_URL=sqlite:///./hive.db
- REDIS_URL=redis://redis:6379
- ENVIRONMENT=development
- LOG_LEVEL=info
- CORS_ORIGINS=http://localhost:3000
volumes:
- ./config:/app/config
depends_on:
- redis
networks:
- hive-network
restart: unless-stopped
# Hive Frontend
hive-frontend:
build:
context: ./frontend
dockerfile: Dockerfile
ports:
- "3001:3000"
environment:
- REACT_APP_API_URL=http://localhost:8087
- REACT_APP_WS_URL=ws://localhost:8087
depends_on:
- hive-backend
networks:
- hive-network
restart: unless-stopped
# PostgreSQL Database
postgres:
image: postgres:15
environment:
- POSTGRES_DB=hive
- POSTGRES_USER=hive
- POSTGRES_PASSWORD=hivepass
- PGDATA=/var/lib/postgresql/data/pgdata
volumes:
- postgres_data:/var/lib/postgresql/data
- ./backend/migrations:/docker-entrypoint-initdb.d
ports:
- "5433:5432"
networks:
- hive-network
restart: unless-stopped
# Redis Cache
redis:
image: redis:7-alpine
command: redis-server --appendonly yes --maxmemory 256mb --maxmemory-policy allkeys-lru
volumes:
- redis_data:/data
ports:
- "6380:6379"
networks:
- hive-network
restart: unless-stopped
# Prometheus Metrics
prometheus:
image: prom/prometheus:latest
command:
- '--config.file=/etc/prometheus/prometheus.yml'
- '--storage.tsdb.path=/prometheus'
- '--web.console.libraries=/etc/prometheus/console_libraries'
- '--web.console.templates=/etc/prometheus/consoles'
- '--storage.tsdb.retention.time=30d'
- '--web.enable-lifecycle'
ports:
- "9091:9090"
volumes:
- ./config/monitoring/prometheus.yml:/etc/prometheus/prometheus.yml
- prometheus_data:/prometheus
networks:
- hive-network
restart: unless-stopped
# Grafana Dashboard
grafana:
image: grafana/grafana:latest
environment:
- GF_SECURITY_ADMIN_USER=admin
- GF_SECURITY_ADMIN_PASSWORD=hiveadmin
- GF_INSTALL_PLUGINS=grafana-clock-panel,grafana-simple-json-datasource
ports:
- "3002:3000"
volumes:
- grafana_data:/var/lib/grafana
- ./config/monitoring/grafana:/etc/grafana/provisioning
depends_on:
- prometheus
networks:
- hive-network
restart: unless-stopped
networks:
hive-network:
driver: bridge
volumes:
postgres_data:
redis_data:
prometheus_data:
grafana_data: