93 lines
2.5 KiB
YAML
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
|