homelab/fighter/config/monitoring/docker-compose.yml

93 lines
2.5 KiB
YAML

version: '3'
services:
grafana:
image: grafana/grafana-oss:latest
container_name: monitoring_grafana
restart: "no"
networks:
- monitoring
- web
user: "0"
volumes:
- ${DOCKER_DATA}/grafana:/var/lib/grafana
- ./custom.ini:/etc/grafana/grafana.ini
labels:
- traefik.http.routers.grafana.rule=Host(`grafana.jafner.net`)
- traefik.http.routers.grafana.tls.certresolver=lets-encrypt
- traefik.http.routers.grafana.tls.options=tls12@file
- traefik.http.routers.grafana.middlewares=securityheaders@file
prometheus:
image: prom/prometheus:latest
container_name: monitoring_prometheus
user: 1000:1000
networks:
- monitoring
- web
ports:
- 9090:9090
volumes:
- ./prometheus.yml:/etc/prometheus/prometheus.yml
- ${DOCKER_DATA}/prometheus:/prometheus
restart: "no"
command:
- "--config.file=/etc/prometheus/prometheus.yml"
labels:
- traefik.http.routers.prometheus-monitoring.rule=Host(`prometheus.jafner.net`)
- traefik.http.routers.prometheus-monitoring.tls.certresolver=lets-encrypt
- traefik.http.routers.prometheus-monitoring.middlewares=traefik-forward-auth-privileged@file
loki:
image: grafana/loki:2.5.0
container_name: monitoring_loki
user: 1000:1000
networks:
- monitoring
- web
ports:
- "3100:3100"
volumes:
- ${DOCKER_DATA}/loki-logs:/loki-logs
- ./loki-config.yml:/etc/loki/loki-config.yml # not sure if this works. If not, just edit the config within the data volume
restart: "no"
command: -config.file=/etc/loki/loki-config.yml
labels:
- traefik.http.routers.loki.rule=Host(`loki.jafner.net`)
- traefik.http.routers.loki.tls.certresolver=lets-encrypt
promtail:
image: grafana/promtail
container_name: monitoring_promtail
networks:
- monitoring
volumes:
- ./promtail-config.yml:/etc/promtail/promtail-config.yml
labels:
- traefik.enable=false
exporter-ping:
image: czerwonk/ping_exporter
container_name: monitoring_exporter-ping
restart: "no"
networks:
- monitoring
volumes:
- ./exporter-ping/config.yml:/config/config.yml
exporter-docker:
image: prometheusnet/docker_exporter
container_name: monitoring_exporter-docker
restart: "no"
networks:
- monitoring
volumes:
- /var/run/docker.sock:/var/run/docker.sock:ro
labels:
- traefik.enable=false
networks:
monitoring:
external: true
web:
external: true