2022-04-22 20:16:39 +02:00
|
|
|
networks:
|
|
|
|
monitoring:
|
|
|
|
driver: bridge
|
2022-04-24 10:38:47 +02:00
|
|
|
traefik:
|
|
|
|
external: true
|
2022-04-22 20:16:39 +02:00
|
|
|
|
|
|
|
services:
|
|
|
|
grafana:
|
2024-09-26 17:01:07 +02:00
|
|
|
image: grafana/grafana:11.2.1
|
2022-04-22 20:16:39 +02:00
|
|
|
container_name: grafana
|
|
|
|
restart: unless-stopped
|
|
|
|
volumes:
|
|
|
|
- ./data/grafana:/var/lib/grafana
|
|
|
|
- ./conf/grafana/provisioning:/etc/grafana/provisioning
|
|
|
|
ports:
|
|
|
|
- 3000:3000
|
|
|
|
environment:
|
|
|
|
- GF_SECURITY_ADMIN_USER=admin
|
|
|
|
- GF_SECURITY_ADMIN_PASSWORD=${GRAFANA_PASSWORD}
|
|
|
|
- GF_USERS_ALLOW_SIGN_UP=false
|
2024-01-23 20:42:08 +01:00
|
|
|
- GF_SERVER_ROOT_URL=https://grafana.${PUBLIC_HOST}
|
|
|
|
- GF_AUTH_GENERIC_OAUTH_ENABLED=true
|
|
|
|
- GF_AUTH_GENERIC_OAUTH_NAME=SSO
|
|
|
|
- GF_AUTH_GENERIC_OAUTH_ALLOW_SIGN_UP=true
|
|
|
|
- GF_AUTH_GENERIC_OAUTH_CLIENT_ID=grafana
|
|
|
|
- GF_AUTH_GENERIC_OAUTH_CLIENT_SECRET=${GRAFANA_CLIENT_SECRET}
|
|
|
|
- GF_AUTH_GENERIC_OAUTH_SCOPES=openid email profile offline_access roles
|
|
|
|
- GF_AUTH_GENERIC_OAUTH_EMAIL_ATTRIBUTE_PATH=email
|
|
|
|
- GF_AUTH_GENERIC_OAUTH_LOGIN_ATTRIBUTE_PATH=preferred_username
|
|
|
|
- GF_AUTH_GENERIC_OAUTH_NAME_ATTRIBUTE_PATH=full_name
|
|
|
|
- GF_AUTH_GENERIC_OAUTH_AUTH_URL=${OPENID_URL}/protocol/openid-connect/auth
|
|
|
|
- GF_AUTH_GENERIC_OAUTH_TOKEN_URL=${OPENID_URL}/protocol/openid-connect/token
|
|
|
|
- GF_AUTH_GENERIC_OAUTH_API_URL=${OPENID_URL}/protocol/openid-connect/userinfo
|
|
|
|
- GF_AUTH_GENERIC_OAUTH_ROLE_ATTRIBUTE_PATH=contains(roles[*], 'admin') && 'Admin' || contains(roles[*], 'editor') && 'Editor' || 'Viewer'
|
2022-04-22 20:16:39 +02:00
|
|
|
networks:
|
|
|
|
- monitoring
|
2022-04-24 10:38:47 +02:00
|
|
|
- traefik
|
|
|
|
labels:
|
|
|
|
- "traefik.enable=true"
|
|
|
|
- "traefik.http.routers.grafana.rule=Host(`grafana.${HOST_SUFFIX}`)"
|
|
|
|
- "traefik.http.routers.grafana.entrypoints=web"
|
2022-04-22 20:16:39 +02:00
|
|
|
prometheus:
|
2024-08-27 14:01:01 +02:00
|
|
|
image: prom/prometheus:v2.54.1
|
2022-04-22 20:16:39 +02:00
|
|
|
container_name: prometheus
|
|
|
|
restart: unless-stopped
|
|
|
|
volumes:
|
|
|
|
- ./conf/prometheus:/etc/prometheus
|
|
|
|
- ./data/prometheus:/prometheus
|
|
|
|
ports:
|
|
|
|
- 9090:9090
|
|
|
|
command:
|
|
|
|
- '--config.file=/etc/prometheus/prometheus.yml'
|
|
|
|
- '--storage.tsdb.path=/prometheus'
|
2024-08-23 09:36:27 +02:00
|
|
|
- '--storage.tsdb.retention.time=120d'
|
2022-04-22 20:16:39 +02:00
|
|
|
- '--web.console.libraries=/etc/prometheus/console_libraries'
|
|
|
|
- '--web.console.templates=/etc/prometheus/consoles'
|
|
|
|
- '--web.enable-lifecycle'
|
2022-04-24 10:38:47 +02:00
|
|
|
- "--web.external-url=http://prometheus.${HOST_SUFFIX}"
|
2022-04-22 20:16:39 +02:00
|
|
|
expose:
|
|
|
|
- 9090
|
|
|
|
networks:
|
|
|
|
- monitoring
|
2022-04-24 10:38:47 +02:00
|
|
|
- traefik
|
|
|
|
labels:
|
|
|
|
- "traefik.enable=true"
|
|
|
|
- "traefik.http.routers.prometheus.rule=Host(`prometheus.${HOST_SUFFIX}`)"
|
|
|
|
- "traefik.http.routers.prometheus.entrypoints=web"
|
2022-04-22 20:16:39 +02:00
|
|
|
alertmanager:
|
2024-02-28 13:01:11 +01:00
|
|
|
image: prom/alertmanager:v0.27.0
|
2022-04-22 20:16:39 +02:00
|
|
|
container_name: alertmanager
|
|
|
|
restart: unless-stopped
|
|
|
|
volumes:
|
|
|
|
- ./conf/alertmanager:/etc/alertmanager
|
|
|
|
- ./data/alertmanager:/alertmanager
|
2022-04-24 10:38:47 +02:00
|
|
|
environment:
|
|
|
|
- TZ=${TZ}
|
2022-04-22 20:16:39 +02:00
|
|
|
ports:
|
|
|
|
- 9093:9093
|
|
|
|
command:
|
|
|
|
- '--config.file=/etc/alertmanager/alertmanager.yml'
|
|
|
|
- '--storage.path=/alertmanager'
|
2022-04-24 10:38:47 +02:00
|
|
|
- "--web.external-url=http://alertmanager.${HOST_SUFFIX}"
|
2022-04-22 20:16:39 +02:00
|
|
|
expose:
|
|
|
|
- 9093
|
|
|
|
networks:
|
|
|
|
- monitoring
|
2022-04-24 10:38:47 +02:00
|
|
|
- traefik
|
|
|
|
labels:
|
|
|
|
- "traefik.enable=true"
|
|
|
|
- "traefik.http.routers.alertmanager.rule=Host(`alertmanager.${HOST_SUFFIX}`)"
|
|
|
|
- "traefik.http.routers.alertmanager.entrypoints=web"
|
2022-04-22 20:16:39 +02:00
|
|
|
node-exporter:
|
2024-07-14 14:01:15 +02:00
|
|
|
image: prom/node-exporter:v1.8.2
|
2022-04-22 20:16:39 +02:00
|
|
|
container_name: node-exporter
|
|
|
|
restart: unless-stopped
|
|
|
|
volumes:
|
|
|
|
- /proc:/host/proc:ro
|
|
|
|
- /sys:/host/sys:ro
|
|
|
|
- /:/rootfs:ro
|
|
|
|
command:
|
|
|
|
- '--path.procfs=/host/proc'
|
|
|
|
- '--path.rootfs=/rootfs'
|
|
|
|
- '--path.sysfs=/host/sys'
|
|
|
|
- '--collector.filesystem.mount-points-exclude=^/(sys|proc|dev|host|etc)($$|/)'
|
|
|
|
expose:
|
|
|
|
- 9100
|
|
|
|
networks:
|
|
|
|
- monitoring
|
|
|
|
blackbox_exporter:
|
2024-04-09 16:00:52 +02:00
|
|
|
image: prom/blackbox-exporter:v0.25.0
|
2022-04-22 20:16:39 +02:00
|
|
|
container_name: blackbox
|
|
|
|
restart: unless-stopped
|
|
|
|
expose:
|
|
|
|
- 9115
|
|
|
|
networks:
|
|
|
|
- monitoring
|
|
|
|
# smokeping:
|
|
|
|
# image: quay.io/superq/smokeping-prober
|
|
|
|
# container_name: smokeping
|
|
|
|
# restart: unless-stopped
|
|
|
|
# command: nyyu.dev
|
|
|
|
# privileged: true
|
|
|
|
# expose:
|
|
|
|
# - 9374
|
|
|
|
# networks:
|
|
|
|
# - monitoring
|
|
|
|
cadvisor:
|
|
|
|
# ARM image
|
2024-07-25 07:01:19 +02:00
|
|
|
image: gcr.io/cadvisor/cadvisor:v0.50.0
|
2022-04-22 20:16:39 +02:00
|
|
|
container_name: cadvisor
|
|
|
|
restart: unless-stopped
|
|
|
|
command:
|
|
|
|
- '--housekeeping_interval=10s'
|
|
|
|
- '--raw_cgroup_prefix_whitelist=/docker/'
|
|
|
|
- '--disable_metrics=cpu_topology,hugetlb'
|
|
|
|
privileged: true
|
|
|
|
pid: 'host'
|
|
|
|
ports:
|
|
|
|
- '8040:8080'
|
|
|
|
volumes:
|
|
|
|
- '/:/rootfs:ro'
|
|
|
|
- '/var/run:/var/run:ro'
|
|
|
|
- '/sys:/sys:ro'
|
|
|
|
- '/var/lib/docker/:/var/lib/docker:ro'
|
|
|
|
- '/dev/disk/:/dev/disk:ro'
|
|
|
|
devices:
|
|
|
|
- '/dev/kmsg:/dev/kmsg'
|
|
|
|
expose:
|
|
|
|
- 8080
|
|
|
|
networks:
|
2022-10-21 22:13:16 +02:00
|
|
|
- monitoring
|