149 lines
3.4 KiB
YAML
149 lines
3.4 KiB
YAML
services:
|
|
# --- Observability stack ---
|
|
jaeger:
|
|
image: jaegertracing/all-in-one:1.62
|
|
environment:
|
|
COLLECTOR_OTLP_ENABLED: "true"
|
|
ports:
|
|
- "16686:16686" # Jaeger UI
|
|
- "4317:4317" # OTLP gRPC receiver
|
|
- "4318:4318" # OTLP HTTP receiver
|
|
|
|
prometheus:
|
|
image: prom/prometheus:v3.2.1
|
|
volumes:
|
|
- ./prometheus.yaml:/etc/prometheus/prometheus.yml:ro
|
|
ports:
|
|
- "9090:9090"
|
|
|
|
grafana:
|
|
image: grafana/grafana:11.6.0
|
|
environment:
|
|
GF_AUTH_ANONYMOUS_ENABLED: "true"
|
|
GF_AUTH_ANONYMOUS_ORG_ROLE: Admin
|
|
ports:
|
|
- "3000:3000"
|
|
depends_on:
|
|
- jaeger
|
|
- prometheus
|
|
|
|
# --- Object storage ---
|
|
minio:
|
|
image: minio/minio:latest
|
|
command: server /data --console-address ":9001"
|
|
environment:
|
|
MINIO_ROOT_USER: minioadmin
|
|
MINIO_ROOT_PASSWORD: minioadmin
|
|
ports:
|
|
- "9000:9000"
|
|
- "9001:9001"
|
|
volumes:
|
|
- minio-data:/data
|
|
|
|
# Create the default bucket on startup.
|
|
minio-init:
|
|
image: minio/mc:latest
|
|
depends_on:
|
|
- minio
|
|
entrypoint: >
|
|
/bin/sh -c "
|
|
sleep 2;
|
|
mc alias set local http://minio:9000 minioadmin minioadmin;
|
|
mc mb --ignore-existing local/sq-segments;
|
|
exit 0;
|
|
"
|
|
|
|
# --- SQ cluster ---
|
|
sq-1:
|
|
build:
|
|
context: ..
|
|
dockerfile: templates/sq-server.Dockerfile
|
|
command:
|
|
- serve
|
|
- --host=0.0.0.0:6060
|
|
- --http-host=0.0.0.0:6062
|
|
environment:
|
|
SQ_NODE_ID: sq-1
|
|
SQ_DATA_DIR: /data
|
|
SQ_SEEDS: sq-2:6060,sq-3:6060
|
|
SQ_CLUSTER_ID: sq-cluster
|
|
SQ_S3_BUCKET: sq-segments
|
|
SQ_S3_ENDPOINT: http://minio:9000
|
|
SQ_S3_REGION: us-east-1
|
|
AWS_ACCESS_KEY_ID: minioadmin
|
|
AWS_SECRET_ACCESS_KEY: minioadmin
|
|
RUST_LOG: info
|
|
OTEL_EXPORTER_OTLP_ENDPOINT: http://jaeger:4317
|
|
ports:
|
|
- "6060:6060"
|
|
- "6062:6062"
|
|
volumes:
|
|
- sq1-data:/data
|
|
depends_on:
|
|
- minio-init
|
|
- jaeger
|
|
|
|
sq-2:
|
|
build:
|
|
context: ..
|
|
dockerfile: templates/sq-server.Dockerfile
|
|
command:
|
|
- serve
|
|
- --host=0.0.0.0:6060
|
|
- --http-host=0.0.0.0:6062
|
|
environment:
|
|
SQ_NODE_ID: sq-2
|
|
SQ_DATA_DIR: /data
|
|
SQ_SEEDS: sq-1:6060,sq-3:6060
|
|
SQ_CLUSTER_ID: sq-cluster
|
|
SQ_S3_BUCKET: sq-segments
|
|
SQ_S3_ENDPOINT: http://minio:9000
|
|
SQ_S3_REGION: us-east-1
|
|
AWS_ACCESS_KEY_ID: minioadmin
|
|
AWS_SECRET_ACCESS_KEY: minioadmin
|
|
RUST_LOG: info
|
|
OTEL_EXPORTER_OTLP_ENDPOINT: http://jaeger:4317
|
|
ports:
|
|
- "6070:6060"
|
|
- "6072:6062"
|
|
volumes:
|
|
- sq2-data:/data
|
|
depends_on:
|
|
- minio-init
|
|
- jaeger
|
|
|
|
sq-3:
|
|
build:
|
|
context: ..
|
|
dockerfile: templates/sq-server.Dockerfile
|
|
command:
|
|
- serve
|
|
- --host=0.0.0.0:6060
|
|
- --http-host=0.0.0.0:6062
|
|
environment:
|
|
SQ_NODE_ID: sq-3
|
|
SQ_DATA_DIR: /data
|
|
SQ_SEEDS: sq-1:6060,sq-2:6060
|
|
SQ_CLUSTER_ID: sq-cluster
|
|
SQ_S3_BUCKET: sq-segments
|
|
SQ_S3_ENDPOINT: http://minio:9000
|
|
SQ_S3_REGION: us-east-1
|
|
AWS_ACCESS_KEY_ID: minioadmin
|
|
AWS_SECRET_ACCESS_KEY: minioadmin
|
|
RUST_LOG: info
|
|
OTEL_EXPORTER_OTLP_ENDPOINT: http://jaeger:4317
|
|
ports:
|
|
- "6080:6060"
|
|
- "6082:6062"
|
|
volumes:
|
|
- sq3-data:/data
|
|
depends_on:
|
|
- minio-init
|
|
- jaeger
|
|
|
|
volumes:
|
|
minio-data:
|
|
sq1-data:
|
|
sq2-data:
|
|
sq3-data:
|