initial commit
This commit is contained in:
41
Readme.md
Normal file
41
Readme.md
Normal file
@@ -0,0 +1,41 @@
|
||||
##### TP nagios
|
||||
|
||||
Cible: B2, IPI ASRBD
|
||||
|
||||
Durée: 4h
|
||||
|
||||
Prérequis: dernière partie du tp snmp
|
||||
|
||||
Prérequis techniques: Une vm avec un agent snmp
|
||||
fichier d'exemple de machine, service, etc. nagios.cfg
|
||||
|
||||
Le TP est volontairement séquencé en courtes étapes afin de pouvoir faire des feedback régulier
|
||||
|
||||
|
||||
### Instructions:
|
||||
|
||||
## Installer nagios
|
||||
1/2h
|
||||
|
||||
|
||||
## Créer une machine
|
||||
1/2h
|
||||
|
||||
## surveiller les éléments de base
|
||||
* load
|
||||
* memoire
|
||||
* espace disque sur /
|
||||
* process nagios
|
||||
|
||||
Montrer et commenter nagios.cfg
|
||||
|
||||
Leur demander de faire le reste
|
||||
1h30
|
||||
|
||||
### Validation:
|
||||
|
||||
### À rendre:
|
||||
|
||||
Réalisation technique
|
||||
|
||||
|
||||
24
nagios.cfg
Normal file
24
nagios.cfg
Normal file
@@ -0,0 +1,24 @@
|
||||
# /etc/nagios/conf.d/hosts.cfg
|
||||
define host {
|
||||
host_name ipi_g2_24
|
||||
address 100.0.2.224
|
||||
use linux-server
|
||||
}
|
||||
|
||||
Définition d'un service:
|
||||
|
||||
#/etc/nagios/conf.d/services.cfg
|
||||
define service {
|
||||
service_description cpuload
|
||||
host_name ipi_g2_24
|
||||
check_command check_snmp_load!70%!80%!
|
||||
use generic-service
|
||||
}
|
||||
|
||||
|
||||
Définition de la commande:
|
||||
#/etc/nagios/conf.d/commands.cfg
|
||||
define command {
|
||||
command_name check_snmp_load
|
||||
command_line $USER1$/check_snmp_load.pl -H $HOSTADDRESS$ -2 -C foobar -w $ARG1$ -c $ARG2$
|
||||
}
|
||||
142
nagios.md
Normal file
142
nagios.md
Normal file
@@ -0,0 +1,142 @@
|
||||
#### Nagios
|
||||
|
||||
### Ressources:
|
||||
|
||||
* https://cours.opendoor.fr/Fichiers/B2/nagios.pdf
|
||||
* https://assets.nagios.com/downloads/nagioscore/docs/nagioscore/4/en/objectdefinitions.html#host
|
||||
|
||||
|
||||
|
||||
### Installation
|
||||
|
||||
|
||||
yum install epel-release
|
||||
|
||||
yum install nagios nagios-plugins-all
|
||||
|
||||
lancer et activer le service
|
||||
|
||||
```
|
||||
systemctl start nagios.service
|
||||
systemctl enable nagios.service
|
||||
|
||||
systemctl enable --now nagios
|
||||
```
|
||||
|
||||
définir le mot de passe d'accès à l'interface:
|
||||
|
||||
```
|
||||
htpasswd /etc/nagios/passwd nagiosadmin
|
||||
```
|
||||
|
||||
```
|
||||
sudo apachectl configtest && sudo systemctl restart httpd
|
||||
```
|
||||
|
||||
### Post configuration
|
||||
|
||||
Rajouter dans le fichier de configuration principal la directive permettant d'inclure tous les fichiers du répertoire _/etc/nagios/conf.d_
|
||||
|
||||
Créer ce répertoire
|
||||
|
||||
Déplacer les scripts check_snmp que nous avons précédemment téléchargés dans /etc/nagios/scripts (penser à créer ce répertoire).
|
||||
|
||||
S'assurer que ces scripts soient exécutables par tout le monde.
|
||||
|
||||
### Définition d'un groupe de machine
|
||||
|
||||
|
||||
Créer le fichier _/etc/nagios/conf.d/hostgroups.cfg_ dans lequel vous définirez un group nommé "my_machines"
|
||||
|
||||
### Définition d'une machine
|
||||
En vous aidant entre autre du fichier /etc/nagios/objects/localhost.cfg
|
||||
|
||||
Créer le fichier _/etc/nagios/conf.d/hosts.cfg_
|
||||
|
||||
Dans ce fichier, rajouter la définition de votre machine avec son nom tel que renvoyé par la commande _hostname -s_ et son adresse ip locale ( _ip a_).
|
||||
|
||||
Cette définition utilisera le modèle _linux-server_
|
||||
|
||||
Cette machine sera membre du groupe my_machines précédemment créé.
|
||||
|
||||
Après avoir vérifié la validité de la configuration nagios et avoir redémarré le service nagios, la machine doit apparaître dans l'interface.
|
||||
|
||||
### Définition d'une commande
|
||||
|
||||
Lors d'un précédent tp, nous avons mis au point les lignes de commandes permettant d'utiliser les scripts check_snmp avec les bons paramètres dans le but de surveiller certains éléments de notre système.
|
||||
|
||||
Pour rappel, les éléments à surveiller sont les suivants:
|
||||
|
||||
* charge cpu
|
||||
* charge mémoire
|
||||
* espace disque disponible sur /
|
||||
* nb de processus crond > 1
|
||||
* nb de processus sshd > 1
|
||||
|
||||
L'objectif est d'utiliser ces lignes de commandes comme commandes nagios
|
||||
|
||||
Vous pouvez vous inspirer du fichier _/etc/nagios/objects/commands.cfg_
|
||||
|
||||
Créer le fichier _/etc/nagios/conf.d/commands.cfg_
|
||||
|
||||
Vous y définirez les commandes suivantes:
|
||||
|
||||
* check_cpu
|
||||
* check_mem
|
||||
* check_disk
|
||||
* check_process
|
||||
|
||||
### Définition d'un service
|
||||
|
||||
En prenant pour exemple le fichier _/etc/nagios/objects/localhost.cfg_
|
||||
|
||||
Créer le fichier _/etc/nagios/conf.d/services.cfg_ dans lequel vous définirez les services suivants:
|
||||
|
||||
* cpu
|
||||
* mem
|
||||
* disk
|
||||
* process_cron
|
||||
* process_ssh
|
||||
|
||||
Chacun de ces services utilisera la commande nagios précédemment définie et sera associé au group my_machines.
|
||||
|
||||
|
||||
### Variables
|
||||
|
||||
Il est possible d'utiliser des variables dans la définition d'une commande, cela évite de dupliquer du code.
|
||||
|
||||
Notamment, l'adresse de la machine cible est stockée dans la variable $HOSTADDRESS$
|
||||
|
||||
On peut également passer des arguments aux commandes. Ceux-ci sont récupérés dans les variables $ARG1$, $ARG2, etc...
|
||||
|
||||
On peut utiliser ce mécanisme pour passer les seuils d'alerte, plutôt que de les définir en dur dans la commande:
|
||||
|
||||
_ce service appel la commande check_local_user avec les paramètres 20 et 50_
|
||||
```
|
||||
define service {
|
||||
use local-service
|
||||
host_name localhost
|
||||
service_description Current Users
|
||||
check_command check_local_users!20!50
|
||||
}
|
||||
```
|
||||
_et voila comment la commande correspondante récupére et utilise ces arguments:_
|
||||
```
|
||||
define command {
|
||||
command_name check_local_users
|
||||
command_line $USER1$/check_users -w $ARG1$ -c $ARG2$
|
||||
}
|
||||
```
|
||||
|
||||
|
||||
|
||||
|
||||
### Validation
|
||||
|
||||
À l'issue de toutes ces opérations, après avoir redémarré nagios, vous devriez obtenir quelque chose qui ressemble à ça.
|
||||
|
||||
Ce n'est pas grave s'il y a des éléments en rouge car en dehors des clous.
|
||||
|
||||

|
||||
|
||||
|
||||
BIN
résultat.png
Normal file
BIN
résultat.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 83 KiB |
Reference in New Issue
Block a user