1
0
Selfhosted-config/monitoring.yml

99 lines
3.3 KiB
YAML

services:
prometheus:
image: prom/prometheus:v3.4.0
container_name: prometheus
privileged: true
user: root
restart: unless-stopped
volumes:
- ./config/prometheus:/etc/prometheus
- ./hdd0/prometheus:/prometheus
command:
- --config.file=/etc/prometheus/prometheus.yml
- --storage.tsdb.path=/prometheus
- --web.console.libraries=/usr/share/prometheus/console_libraries
- --web.console.templates=/usr/share/prometheus/consoles
- --web.enable-lifecycle
labels:
- traefik.enable=true
- traefik.http.routers.prometheus.rule=Host(`prometheus.bouvais.lu`)
- traefik.http.routers.prometheus.entrypoints=websecure
- traefik.http.routers.prometheus.tls.certresolver=myresolver
- traefik.http.routers.prometheus.service=prometheus
- traefik.http.services.prometheus.loadbalancer.server.port=9090
- traefik.http.routers.prometheus.middlewares=auth@docker
depends_on:
- cadvisor
- node-exporter
grafana:
image: grafana/grafana:12.0.1
container_name: grafana
privileged: true
user: root
restart: unless-stopped
volumes:
- ./hdd0/grafana:/var/lib/grafana
environment:
- GF_SECURITY_ADMIN_USER=adrien
- GF_SECURITY_ADMIN_PASSWORD=${GRAFANA_MY_PASSWORD}
- GF_SERVER_ROOT_URL=https://grafana.bouvais.lu
labels:
- traefik.enable=true"
- traefik.http.routers.grafana.rule=Host(`grafana.bouvais.lu`)
- traefik.http.routers.grafana.entrypoints=websecure
- traefik.http.routers.grafana.tls.certresolver=myresolver
- traefik.http.routers.grafana.service=grafana
- traefik.http.services.grafana.loadbalancer.server.port=3000
- traefik.http.routers.grafana.middlewares=auth@docker
depends_on:
- prometheus
cadvisor:
image: gcr.io/cadvisor/cadvisor:v0.52.0
container_name: cadvisor
privileged: true
restart: unless-stopped
volumes:
- /:/rootfs:ro
- /var/run:/var/run:rw
- /sys:/sys:ro
- /var/lib/docker/:/var/lib/docker:ro
- /dev/disk/:/dev/disk:ro
devices:
- /dev/kmsg:/dev/kmsg
node-exporter:
image: prom/node-exporter:v1.9.1
container_name: node-exporter
privileged: true
restart: unless-stopped
volumes:
- /proc:/host/proc:ro
- /sys:/host/sys:ro
- /:/rootfs:ro
command:
- --path.procfs=/host/proc
- --path.sysfs=/host/sys
- --path.rootfs=/rootfs
- --collector.filesystem.mount-points-exclude=^/(sys|proc|dev|host|etc|rootfs/var/lib/docker/containers|rootfs/var/lib/docker/overlay2|rootfs/run/docker/netns|rootfs/var/lib/docker/aufs)($$|/)
nvidia-gpu-exporter:
image: utkuozdemir/nvidia_gpu_exporter:1.3.1
container_name: nvidia-gpu-exporter
restart: unless-stopped
privileged: true
devices:
- /dev/nvidia0:/dev/nvidia0
volumes:
- /usr/bin/nvidia-smi:/usr/bin/nvidia-smi:ro
- /usr/lib/x86_64-linux-gnu/libnvidia-ml.so:/usr/lib/x86_64-linux-gnu/libnvidia-ml.so:ro
- /usr/lib/x86_64-linux-gnu/libnvidia-ml.so.1:/usr/lib/x86_64-linux-gnu/libnvidia-ml.so.1:ro
command:
- --web.listen-address=:9835
- --web.telemetry-path=/metrics
- --nvidia-smi-command=nvidia-smi
- --log.level=info
- --query-field-names=AUTO
- --log.format=logfmt