Rework prometheus blackbox monitoring configuration
* Use scrape_config_files correctly * Do not separate prometheus and blackbox exporter nodes * Add a http_2xx_selfsigned module for self-signed certs * Monitor missing services * Switch from CRLF to LF in prometheus.config.j2
This commit is contained in:
+3
-3
@@ -22,6 +22,6 @@ all:
|
||||
reverse-proxy.labolyon.dn42:
|
||||
wiki.labolyon.dn42:
|
||||
zigbee2mqtt.labolyon.dn42:
|
||||
# blackbox:
|
||||
# hosts:
|
||||
# monitoring:
|
||||
monitoring:
|
||||
hosts:
|
||||
monitoring.labolyon.dn42:
|
||||
|
||||
@@ -12,21 +12,11 @@
|
||||
become: yes
|
||||
roles:
|
||||
- prometheus
|
||||
- blackbox-exporter
|
||||
vars:
|
||||
blackbox: false
|
||||
scrape_files:
|
||||
- /etc/prometheus/scrape-main.yml
|
||||
|
||||
#- name: Install and configure Prometheus node - Blackbox nodes
|
||||
# hosts: blackbox
|
||||
# become: yes
|
||||
# roles:
|
||||
# - prometheus
|
||||
# - blackbox-exporter
|
||||
# vars:
|
||||
# blackbox: true
|
||||
# scrape_files:
|
||||
# - /etc/prometheus/scrape-blackbox.yml
|
||||
- /etc/prometheus/scrape-blackbox.yml
|
||||
|
||||
- name: Install and configure nodes
|
||||
hosts: all
|
||||
|
||||
@@ -8,6 +8,11 @@ modules:
|
||||
preferred_ip_protocol: "ip4"
|
||||
ip_protocol_fallback: true
|
||||
{% endif %}
|
||||
http_2xx_selfsigned:
|
||||
prober: http
|
||||
http:
|
||||
tls_config:
|
||||
insecure_skip_verify: true
|
||||
http_post_2xx:
|
||||
prober: http
|
||||
{% if inventory_hostname == 'check.home.arpa' %}
|
||||
|
||||
@@ -1,75 +1,31 @@
|
||||
{{ ansible_managed | comment }}
|
||||
|
||||
# Global configuration
|
||||
global:
|
||||
scrape_interval: 15s # Set the scrape interval to every 15 seconds. Default is every 1 minute.
|
||||
evaluation_interval: 15s # Evaluate rules every 15 seconds. The default is every 1 minute.
|
||||
# scrape_timeout is set to the global default (10s).
|
||||
|
||||
# Alertmanager configuration
|
||||
alerting:
|
||||
alertmanagers:
|
||||
- static_configs:
|
||||
- targets:
|
||||
- localhost:9093
|
||||
|
||||
# Load rules once and periodically evaluate them according to the global 'evaluation_interval'.
|
||||
rule_files:
|
||||
- "{{ alertmanager_rules }}/prometheus.rules.yml"
|
||||
- "{{ alertmanager_rules }}/blackbox.rules.yml"
|
||||
- "{{ alertmanager_rules }}/hosts.rules.yml"
|
||||
|
||||
# A scrape configuration containing exactly one endpoint to scrape:
|
||||
|
||||
#scrape_config_files:
|
||||
#{% for item in scrape_files %}
|
||||
# - "{{ item }}"
|
||||
#{% endfor %}
|
||||
|
||||
scrape_configs:
|
||||
- job_name: "prometheus"
|
||||
static_configs:
|
||||
- targets: ["localhost:9090"]
|
||||
|
||||
{% if blackbox %}
|
||||
- job_name: "blackbox"
|
||||
metrics_path: /probe
|
||||
params:
|
||||
module: [http_2xx]
|
||||
scrape_interval: 5s
|
||||
static_configs:
|
||||
- targets:
|
||||
- https://labolyon.fr
|
||||
- https://mail.labolyon.fr
|
||||
- https://wiki.labolyon.fr
|
||||
- https://git.labolyon.fr
|
||||
relabel_configs:
|
||||
- source_labels: [__address__]
|
||||
target_label: __param_target
|
||||
- source_labels: [__param_target]
|
||||
target_label: target
|
||||
- target_label: __address__
|
||||
replacement: 127.0.0.1:9115 # The blackbox exporter's real hostname:port.
|
||||
{% else %}
|
||||
- job_name: "linux-nodes"
|
||||
static_configs:
|
||||
- targets:
|
||||
- ansible.labolyon.dn42:9100
|
||||
- dn42-router.labolyon.dn42:9100
|
||||
- dns.labolyon.dn42:9100
|
||||
- git.labolyon.dn42:9100
|
||||
- i2p.labolyon.dn42:9100
|
||||
- labolyon-fr.labolyon.dn42:9100
|
||||
- lolix-ixpman.labolyon.dn42:9100
|
||||
- lolix-rs1.labolyon.dn42:9100
|
||||
- lolmox.labolyon.dn42:9100
|
||||
- lolmox2.labolyon.dn42:9100
|
||||
- mail.labolyon.dn42:9100
|
||||
- matrix.labolyon.dn42:9100
|
||||
- monitoring.labolyon.dn42:9100
|
||||
- mosquitto.labolyon.dn42:9100
|
||||
- radius.labolyon.dn42:9100
|
||||
- reverse-proxy.labolyon.dn42:9100
|
||||
- wiki.labolyon.dn42:9100
|
||||
- zigbee2mqtt.labolyon.dn42:9100
|
||||
{% endif %}
|
||||
{{ ansible_managed | comment }}
|
||||
|
||||
# Global configuration
|
||||
global:
|
||||
scrape_interval: 15s # Set the scrape interval to every 15 seconds. Default is every 1 minute.
|
||||
evaluation_interval: 15s # Evaluate rules every 15 seconds. The default is every 1 minute.
|
||||
# scrape_timeout is set to the global default (10s).
|
||||
|
||||
# Alertmanager configuration
|
||||
alerting:
|
||||
alertmanagers:
|
||||
- static_configs:
|
||||
- targets:
|
||||
- localhost:9093
|
||||
|
||||
# Load rules once and periodically evaluate them according to the global 'evaluation_interval'.
|
||||
rule_files:
|
||||
- "{{ alertmanager_rules }}/prometheus.rules.yml"
|
||||
- "{{ alertmanager_rules }}/blackbox.rules.yml"
|
||||
- "{{ alertmanager_rules }}/hosts.rules.yml"
|
||||
|
||||
# A scrape configuration containing exactly one endpoint to scrape:
|
||||
scrape_config_files:
|
||||
{% for item in scrape_files %}
|
||||
- "{{ item }}"
|
||||
{% endfor %}
|
||||
|
||||
scrape_configs:
|
||||
- job_name: "prometheus"
|
||||
static_configs:
|
||||
- targets: ["localhost:9090"]
|
||||
|
||||
@@ -1,4 +1,8 @@
|
||||
- job_name: "blackbox"
|
||||
# managed by ansible
|
||||
|
||||
scrape_configs:
|
||||
|
||||
- job_name: "blackbox-public-https"
|
||||
metrics_path: /probe
|
||||
params:
|
||||
module: [http_2xx]
|
||||
@@ -9,10 +13,30 @@
|
||||
- https://mail.labolyon.fr
|
||||
- https://wiki.labolyon.fr
|
||||
- https://git.labolyon.fr
|
||||
- https://sso.labolyon.fr
|
||||
- https://chat.labolyon.fr
|
||||
- https://grafana.labolyon.fr
|
||||
relabel_configs:
|
||||
- source_labels: [__address__]
|
||||
target_label: __param_target
|
||||
- source_labels: [__param_target]
|
||||
target_label: target
|
||||
target_label: instance
|
||||
- target_label: __address__
|
||||
replacement: 127.0.0.1:9115 # The blackbox exporter's real hostname:port.
|
||||
|
||||
- job_name: "blackbox-internal-https"
|
||||
metrics_path: /probe
|
||||
params:
|
||||
module: [http_2xx_selfsigned]
|
||||
scrape_interval: 5s
|
||||
static_configs:
|
||||
- targets:
|
||||
- https://octoprint.labolyon.dn42/login/
|
||||
- https://stickers.labolyon.dn42
|
||||
relabel_configs:
|
||||
- source_labels: [__address__]
|
||||
target_label: __param_target
|
||||
- source_labels: [__param_target]
|
||||
target_label: instance
|
||||
- target_label: __address__
|
||||
replacement: 127.0.0.1:9115 # The blackbox exporter's real hostname:port.
|
||||
|
||||
@@ -1,3 +1,4 @@
|
||||
scrape_configs:
|
||||
- job_name: "linux-nodes"
|
||||
static_configs:
|
||||
- targets:
|
||||
|
||||
Reference in New Issue
Block a user