|
| 1 | +version: '3.8' |
| 2 | + |
| 3 | +services: |
| 4 | + # Main agent-eval-harness service |
| 5 | + agent-eval-harness: |
| 6 | + build: |
| 7 | + context: . |
| 8 | + dockerfile: Dockerfile |
| 9 | + ports: |
| 10 | + - "3000:3000" |
| 11 | + environment: |
| 12 | + - NODE_ENV=development |
| 13 | + - ANTHROPIC_API_KEY=${ANTHROPIC_API_KEY:-} |
| 14 | + - OPENAI_API_KEY=${OPENAI_API_KEY:-} |
| 15 | + - OTEL_EXPORTER_OTLP_ENDPOINT=http://otel-collector:4318 |
| 16 | + volumes: |
| 17 | + - ./trajectories:/app/trajectories |
| 18 | + - ./results:/app/results |
| 19 | + - ./golden:/app/golden |
| 20 | + depends_on: |
| 21 | + - otel-collector |
| 22 | + command: ["node", "dist/cli.js", "serve", "--port", "3000", "--host", "0.0.0.0"] |
| 23 | + |
| 24 | + # OpenTelemetry Collector |
| 25 | + otel-collector: |
| 26 | + image: otel/opentelemetry-collector:latest |
| 27 | + ports: |
| 28 | + - "4317:4317" # OTLP gRPC |
| 29 | + - "4318:4318" # OTLP HTTP |
| 30 | + volumes: |
| 31 | + - ./otel-collector-config.yaml:/etc/otel/config.yaml |
| 32 | + command: ["--config", "/etc/otel/config.yaml"] |
| 33 | + |
| 34 | + # Jaeger for tracing visualization |
| 35 | + jaeger: |
| 36 | + image: jaegertracing/all-in-one:latest |
| 37 | + ports: |
| 38 | + - "16686:16686" # Jaeger UI |
| 39 | + - "14268:14268" # Jaeger ingest |
| 40 | + environment: |
| 41 | + - COLLECTOR_OTLP_ENABLED=true |
| 42 | + |
| 43 | + # TODO: Replace with actual mock LLM image |
| 44 | + # mock-llm: |
| 45 | + # image: TODO |
| 46 | + # ports: |
| 47 | + # - "8080:8080" |
| 48 | + # environment: |
| 49 | + # - PORT=8080 |
| 50 | + # - MOCK_RESPONSES=true |
| 51 | + |
| 52 | + # Prometheus for metrics |
| 53 | + prometheus: |
| 54 | + image: prom/prometheus:latest |
| 55 | + ports: |
| 56 | + - "9090:9090" |
| 57 | + volumes: |
| 58 | + - ./prometheus.yaml:/etc/prometheus/prometheus.yml |
| 59 | + command: |
| 60 | + - '--config.file=/etc/prometheus/prometheus.yml' |
| 61 | + - '--storage.tsdb.path=/prometheus' |
| 62 | + - '--web.console.libraries=/etc/prometheus/console_libraries' |
| 63 | + - '--web.console.templates=/etc/prometheus/consoles' |
| 64 | + |
| 65 | + # Grafana for dashboards |
| 66 | + grafana: |
| 67 | + image: grafana/grafana:latest |
| 68 | + ports: |
| 69 | + - "3001:3000" |
| 70 | + environment: |
| 71 | + - GF_SECURITY_ADMIN_PASSWORD=${GRAFANA_ADMIN_PASSWORD:-admin} |
| 72 | + volumes: |
| 73 | + - grafana-data:/var/lib/grafana |
| 74 | + depends_on: |
| 75 | + - prometheus |
| 76 | + |
| 77 | +volumes: |
| 78 | + grafana-data: |
0 commit comments