All checks were successful
CI / Unit & Component Tests (pull_request) Successful in 3m21s
CI / OCR Service Tests (pull_request) Successful in 16s
CI / Backend Unit Tests (pull_request) Successful in 4m31s
CI / fail2ban Regex (pull_request) Successful in 38s
CI / Compose Bucket Idempotency (pull_request) Successful in 57s
- Add obs-loki (grafana/loki:3.4.2) to docker-compose.observability.yml with healthcheck (wget /ready), expose-only port 3100, named volume loki_data - Add obs-promtail (grafana/promtail:3.4.2) bridging archiv-net + obs-net, depends_on loki service_healthy, docker.sock:ro, promtail_positions volume for restart-safe position tracking - Create infra/observability/loki/loki-config.yml: single-node TSDB schema v13, 30-day retention, auth disabled (obs-net only), telemetry off - Create infra/observability/promtail/promtail-config.yml: Docker SD scrape, container_name / compose_service / compose_project / logstream labels - Update docs/DEPLOYMENT.md §4 with service table and Loki quick-check commands Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
31 lines
1.3 KiB
YAML
31 lines
1.3 KiB
YAML
server:
|
|
http_listen_port: 9080
|
|
grpc_listen_port: 0 # gRPC disabled — used for Promtail clustering only; single-node deployment
|
|
|
|
positions:
|
|
filename: /tmp/positions.yaml # /tmp is a named volume (promtail_positions) — persists across restarts
|
|
|
|
clients:
|
|
- url: http://loki:3100/loki/api/v1/push
|
|
# Loki HTTP API is unauthenticated internally. Any container on obs-net can push logs.
|
|
# Acceptable: only trusted application containers join this network.
|
|
|
|
scrape_configs:
|
|
- job_name: docker-containers
|
|
docker_sd_configs:
|
|
- host: unix:///var/run/docker.sock
|
|
refresh_interval: 5s
|
|
relabel_configs:
|
|
- source_labels: ['__meta_docker_container_name']
|
|
regex: '/(.*)'
|
|
target_label: 'container_name'
|
|
# Note: container_name differs between dev (archive-backend) and prod
|
|
# (archiv-production-backend-1). Prefer compose_service for stable LogQL
|
|
# queries across environments — it is stable: backend, db, minio, etc.
|
|
- source_labels: ['__meta_docker_container_label_com_docker_compose_service']
|
|
target_label: 'compose_service'
|
|
- source_labels: ['__meta_docker_container_label_com_docker_compose_project']
|
|
target_label: 'compose_project'
|
|
- source_labels: ['__meta_docker_container_log_stream']
|
|
target_label: 'logstream'
|