services: prometheus: image: prom/prometheus:latest container_name: prometheus restart: unless-stopped volumes: - ./prometheus:/etc/prometheus - prometheus_data:/prometheus command: - '--config.file=/etc/prometheus/prometheus.yml' - '--storage.tsdb.path=/prometheus' - '--web.console.libraries=/etc/prometheus/console_libraries' - '--web.console.templates=/etc/prometheus/consoles' - '--storage.tsdb.retention.time=30d' - '--web.enable-lifecycle' networks: - monitoring - traefik-public - database-internal labels: - "traefik.enable=true" - "traefik.http.routers.prometheus.rule=Host(`prometheus.ai-impress.com`)" - "traefik.http.routers.prometheus.entrypoints=websecure" - "traefik.http.routers.prometheus.tls.certresolver=cloudflare" - "traefik.http.routers.prometheus.middlewares=authentik@file" - "traefik.http.services.prometheus.loadbalancer.server.port=9090" grafana: image: grafana/grafana:latest container_name: grafana restart: unless-stopped volumes: - ./grafana:/var/lib/grafana - ./grafana/provisioning:/etc/grafana/provisioning environment: - GF_SECURITY_ADMIN_PASSWORD=GrafanaAdmin2025!Secure - GF_USERS_ALLOW_SIGN_UP=false - GF_SERVER_ROOT_URL=https://grafana.ai-impress.com - GF_SERVER_DOMAIN=grafana.ai-impress.com - GF_AUTH_DISABLE_LOGIN_FORM=false - GF_AUTH_ANONYMOUS_ENABLED=false networks: - monitoring - traefik-public depends_on: - prometheus labels: - "traefik.enable=true" - "traefik.http.routers.grafana.rule=Host(`grafana.ai-impress.com`)" - "traefik.http.routers.grafana.entrypoints=websecure" - "traefik.http.routers.grafana.tls.certresolver=cloudflare" - "traefik.http.services.grafana.loadbalancer.server.port=3000" node-exporter: image: prom/node-exporter:latest 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)($$|/)' networks: - monitoring cadvisor: image: gcr.io/cadvisor/cadvisor:latest container_name: cadvisor restart: unless-stopped privileged: true devices: - /dev/kmsg volumes: - /:/rootfs:ro - /var/run:/var/run:ro - /sys:/sys:ro - /var/lib/docker/:/var/lib/docker:ro - /dev/disk/:/dev/disk:ro networks: - monitoring alertmanager: image: prom/alertmanager:latest container_name: alertmanager restart: unless-stopped volumes: - ./alertmanager:/etc/alertmanager command: - '--config.file=/etc/alertmanager/config.yml' - '--storage.path=/alertmanager' networks: - monitoring networks: monitoring: driver: bridge traefik-public: external: true database-internal: external: true volumes: prometheus_data: driver: local grafana_data: driver: local