feat: add capnp

Signed-off-by: kjuulh <contact@kjuulh.io>
This commit is contained in:
2026-02-27 12:15:35 +01:00
parent 3162971c89
commit 749ae245c7
115 changed files with 16596 additions and 31 deletions

View File

@@ -0,0 +1,148 @@
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: