This commit is contained in:
Elvire 2025-10-24 13:02:15 +00:00
parent 890a2fa1a3
commit 6604b6d123

View File

@ -1,21 +1,30 @@
1⃣ Objectif
Métriques Apache → récupérées via Apache Exporter → Prometheus → Grafana.
Logs Apache → récupérés via Promtail → Loki → Grafana.
Vue complète dans Grafana avec métriques + logs.
Étape 1 : Installer Apache sur la machine à superviser
2⃣ Sur la VM qui héberge Apache (la VM à superviser)
Pour vérifier si Apache est déjà installé :
dpkg -l | grep apache2
2.1 Installer Apache Exporter
Télécharger lexporter et le rendre exécutable :
Si la commande retourne un numéro de version, Apache est déjà installé. Sinon :
Sur Ubuntu/Debian :
sudo apt update
sudo apt install apache2 -y
sudo systemctl enable apache2
sudo systemctl start apache2
sudo systemctl status apache2
Étape 2 : Installer le module de métriques pour Prometheus
Prometheus ne peut pas lire directement les métriques Apache. On utilise apache_exporter.
2.1 Télécharger apache_exporter
cd /opt
wget https://github.com/Lusitaniae/apache_exporter/releases/download/v1.0.10/apache_exporter-1.0.10.linux-amd64.tar.gz
tar -xvf apache_exporter-1.0.10.linux-amd64.tar.gz
sudo wget https://github.com/Lusitaniae/apache_exporter/releases/download/v1.0.10/apache_exporter-1.0.10.linux-amd64.tar.gz
sudo tar -xvf apache_exporter-1.0.10.linux-amd64.tar.gz
sudo mv apache_exporter-1.0.10.linux-amd64/apache_exporter /usr/local/bin/
Créer un service systemd pour Apache Exporter :
***
sudo tee /etc/systemd/system/apache_exporter.service <<EOF
2.2 Créer un service systemd pour apache_exporter
sudo nano /etc/systemd/system/apache_exporter.service
[Unit]
Description=Prometheus Apache Exporter
After=network.target
@ -26,34 +35,38 @@ ExecStart=/usr/local/bin/apache_exporter --scrape_uri="http://localhost/server-s
[Install]
WantedBy=multi-user.target
EOF
***
Activer et démarrer le service :
2.3 Activer le module status dApache
sudo a2enmod status
sudo systemctl restart apache2
2.4 Démarrer apache_exporter
sudo systemctl daemon-reload
sudo systemctl enable --now apache_exporter
sudo systemctl enable apache_exporter
sudo systemctl start apache_exporter
sudo systemctl status apache_exporter
Vérifier le endpoint des métriques :
curl http://localhost:9117/metrics
✅ À ce stade, Prometheus pourra scrapper les métriques Apache sur le port par défaut 9117 :
2.2 Configurer Promtail pour les logs Apache
http://<IP_MACHINE2>:9117/metrics//vérifier ça sur le site prometheus
Étape 4 : Collecter les logs Apache via Loki + Promtail
4.1 Installer Promtail sur la machine supervisée
Si Promtail nest pas encore installé, tu peux le télécharger depuis Grafana :
cd /opt
wget https://github.com/grafana/loki/releases/latest/download/promtail-linux-amd64.zip
unzip promtail-linux-amd64.zip
sudo wget https://github.com/grafana/loki/releases/download/v2.9.0/promtail-linux-amd64.zip
sudo unzip promtail-linux-amd64.zip
sudo mv promtail-linux-amd64 /usr/local/bin/promtail
sudo chmod +x /usr/local/bin/promtail
Vérifie que Promtail est bien accessible :
which promtail
promtail --version
4.2 Créer un fichier de config pour Promtail
sudo nano /etc/promtail-config.yaml
Créer le répertoire de config :
sudo mkdir -p /etc/promtail
sudo nano /etc/promtail/promtail-config.yml
Exemple de configuration pour séparer access et error logs :
**
Exemple pour Apache :
server:
http_listen_port: 9080
grpc_listen_port: 0
@ -80,13 +93,10 @@ scrape_configs:
job: apache_error
host: apache_vm
__path__: /var/log/apache2/error.log
4.3 Créer un service systemd pour Promtail
sudo nano /etc/systemd/system/promtail.service
*****
Remplace <IP_VM_SUPERVISION> par lIP de la VM où tourne Loki.
****
Créer le service systemd pour Promtail :
***
sudo tee /etc/systemd/system/promtail.service <<EOF
[Unit]
Description=Promtail service for Apache logs
After=network.target
@ -98,30 +108,9 @@ Restart=always
[Install]
WantedBy=multi-user.target
EOF
****
Activer et démarrer Promtail :
**
sudo systemctl daemon-reload
sudo systemctl enable --now promtail
sudo systemctl status promtail
**
Générer une erreur pour tester :
curl http://localhost/page-inexistante
Vérifier error.log :
tail -f /var/log/apache2/error.log
4⃣ Dans Grafana
Ajouter Prometheus comme datasource (port 9090).
Ajouter Loki comme datasource (port 3100).
Créer un dashboard avec :
**
Métriques Apache : requêtes, connexions, status codes depuis Prometheus.
**
Logs Apache :
job="apache_access" → access logs
job="apache_error" → error logs
**
Tester :
Faire une requête curl http://vmApache/page-inexistante → devrait apparaître dans apache_error.
Vérifier les logs et métriques dans Grafana.
sudo systemctl daemon-reload
sudo systemctl enable promtail
sudo systemctl start promtail
sudo systemctl status promtail