Comment installer le logiciel de surveillance Nagios sur Ubuntu 18.04 LTS

Nagios est un logiciel open-source pour la surveillance des systèmes et des réseaux. Nagios peut surveiller l’activité d’un hôte et de ses services et fournit un avertissement/une alerte si quelque chose de grave se produit sur le serveur. Nagios peut fonctionner sur les systèmes d’exploitation Linux, et nous allons utiliser le serveur Ubuntu 18.04.

Dans ce tutoriel, nous allons te montrer étape par étape l’installation de Nagios 4.4.x sur Ubuntu 18.04. Nous installerons le Nagios Core 4.4.x à partir des sources, nous installerons les plugins nrpe et nagios, puis nous ajouterons l’hôte à surveiller au serveur Nagios.

Conditions préalables

  • 2 serveurs Ubuntu 18.04
    • Serveur Nagios – nom d’hôte : hakase-nagios avec une IP : 10.5.5.11
    • Client Ubuntu – nom d’hôte : client01 avec une IP : 10.5.5. 12
  • Privilèges de racine

Ce que nous allons faire :

  • Installer les paquets Dépendances
  • Installer Nagios Core 4.4.5
  • Installer le plugin Nagios et le plugin NRPE
  • Ajouter l’hôte à surveiller au serveur Nagios
  • Tester

Étape 1 – Installer les dépendances des paquets

Tout d’abord, nous allons mettre à jour le référentiel Ubuntu et installer certaines dépendances de paquets pour l’installation de Nagios.

Mets à jour le référentiel Ubuntu à l’aide de la commande apt ci-dessous.

sudo apt update

Ensuite, installe les dépendances des paquets pour l’installation de Nagios.

sudo apt install -y autoconf bc gawk dc build-essential gcc libc6 make wget unzip apache2 php libapache2-mod-php7.2 libgd-dev libmcrypt-dev make libssl-dev snmp libnet-snmp-perl gettext

Et tu as installé les dépendances des paquets pour le serveur Nagios.

Étape 2 – Installer Nagios Core 4.4.5

Dans cette étape, nous allons installer la dernière version stable Nagios Core 4.4.5. Et nous allons l’installer manuellement à partir de la source.

Télécharge Nagios Core 4.4.5

Va dans ton répertoire personnel et télécharge le code source de Nagios Core.

cd ~/
wget https://github.com/NagiosEnterprises/nagioscore/archive/nagios-4.4.5.tar.gz

Extrais le paquet Nagios et va dans le répertoire Nagios extrait.

tar xzf nagios-4.4.5.tar.gz
cd nagioscore-nagios-4.4.5/

Compile et installe Nagios

Commence par compiler le code source de Nagios et définis la configuration de l’hôte virtuel Apache pour Nagios.

sudo ./configure --with-httpd-conf=/etc/apache2/sites-enabled
sudo make all

Compile Nagios

Crée l’utilisateur et le groupe Nagios, et ajoute l’utilisateur Apache ‘www-data’ au groupe ‘nagios’.

sudo make install-groups-users
sudo usermod -a -G nagios www-data

Installer les groupes et les utilisateurs

Installe les binaires de Nagios, le script du démon de service et le mode de commande.

sudo make install
sudo make install-daemoninit
sudo make install-commandmode

Ensuite, installe la configuration du script d’exemple.

sudo make install-config

Ensuite, installe la configuration Apache pour Nagios et active les modules mod_rewrite et mode_cgi.

sudo make install-webconf
sudo a2enmod rewrite cgi

Maintenant, redémarre le service Apache.

systemctl restart apache2

Et tu as installé le Nagios Core 4.4.5.

Installer la configuration de Nagios

Crée l’utilisateur nagiosadmin

Après avoir installé le Nagios Core, nous allons ajouter l’authentification de base pour accéder au tableau de bord de Nagios. Et nous allons utiliser l’authentification de base Apache.

Crée une nouvelle authentification de base Apache pour l’utilisateur « nagiosadmin ».

sudo htpasswd -c /usr/local/nagios/etc/htpasswd.users nagiosadmin

Tape ton mot de passe fort.

Définir le mot de passe de l'administrateur de Nagios

Et tu as créé un nouvel utilisateur ‘nagiosadmin’ pour l’authentification du tableau de bord Nagios.

Configurer le pare-feu UFW

Pour la configuration du pare-feu, tu dois ajouter le service Apache et le port du serveur Nagios au pare-feu UFW.

Ajoute le port HTTP d’Apache et le port de Nagios  » en utilisant la commande ufw ci-dessous.

sudo ufw allow Apache

Recharge maintenant le pare-feu UFW.

sudo ufw reload

Et tu as terminé l’installation de Nagios Core sur le serveur Ubuntu 18.04.

Configurer le pare-feu UFW

Étape 3 – Installe les plugins Nagios et le plugin NRPE

Après avoir installé le Nagios Core, nous allons installer les Nagios Plugins et les NRPE Plugins.

Les plugins Nagios et NRPE sont tous deux disponibles par défaut sur le dépôt Ubuntu. Tu peux installer ces paquets à l’aide de la commande apt ci-dessous.

sudo apt install nagios-plugins nagios-nrpe-plugin

Une fois l’installation terminée, va dans le répertoire d’installation de nagios « /usr/local/nagios » et modifie le fichier de configuration « nagios.cfg ».

cd /usr/local/nagios/
vim nagios.cfg

Décommente le répertoire de configuration supplémentaire pour les serveurs.

cfg_dir=/usr/local/nagios/etc/servers

Sauvegarde et ferme.

Crée maintenant un nouveau répertoire « /usr/local/nagios/etc/servers » qui sera utilisé pour stocker la configuration du moniteur d’hôtes.

mkdir -p /usr/local/nagios/etc/servers

Ensuite, va dans le répertoire « /usr/local/nagios/etc/ » et modifie le fichier de configuration « resurces.cfg ».

cd /usr/local/nagios/etc/
vim resources.cfg

Change le répertoire par défaut pour les plugins Nagios comme ci-dessous.

$USER1$=/usr/lib/nagios/plugins

Sauvegarde et ferme.

Ensuite, ajoute les contacts de l’administrateur de Nagios en éditant le fichier de configuration « objects/contacts.cfg ».

vim objects/contacts.cfg

Change l’adresse e-mail avec la tienne.

define contact{
        ......
        email [email protected]
}

Sauvegarde et ferme.

Ensuite, définis la commande nrpe check en éditant le fichier de configuration « objects/commands.cfg ».

vim objects/commands.cfg

Colle la configuration suivante à la fin de la ligne.

define command{
        command_name check_nrpe
        command_line $USER1$/check_nrpe -H $HOSTADDRESS$ -c $ARG1$
}

Sauvegarde et ferme.

Maintenant, démarre le service Nagios et ajoute-le au démarrage du système.

systemctl start nagios
systemctl enable nagios

Configure nagios, puis redémarre-le pour appliquer les modifications

Le service Nagios est en place et fonctionne, vérifie-le à l’aide de la commande suivante.

systemctl status nagios

Voici le résultat.

Vérifie le statut de nagios

Ensuite, nous devons redémarrer le service Apache pour appliquer une nouvelle configuration de Nagios.

systemctl restart apache2

Après cela, ouvre ton navigateur Web et tape l’adresse IP du serveur en suivant le chemin URL « nagios ».

http://10.5.5.11/nagios/

Connecte-toi avec l’utilisateur « nagiosadmin » et tape ton mot de passe.

Connexion à Nagios

Et tu obtiendras le tableau de bord Nagios comme ci-dessous.

Tableau de bord Nagios

Tu as donc installé Nagios sur le serveur Ubuntu 18.04. Et tu es en mesure d’ajouter des hôtes au serveur Nagios.

Étape 5 – Ajouter un hôte Linux au moniteur

Dans cette étape, nous allons ajouter le serveur Ubuntu avec le nom d’hôte « client01 » et l’adresse IP « 10.5.5.12 » au serveur Nagios.

Installe le serveur NRPE sur le serveur « client01

Connecte-toi au serveur « client01 » en utilisant ton ssh.

ssh [email protected]

Une fois que tu t’es connecté, mets à jour le référentiel Ubuntu et installe les plugins Nagios et le serveur NRPE.

sudo apt update
sudo apt install nagios-nrpe-server nagios-plugins

Ensuite, va dans le répertoire d’installation de NRPE « /etc/nagios » et modifie le fichier de configuration « nrpe.cfg ».

cd /etc/nagios/
vim nrpe.cfg

Décommente la ligne « server_address » et change la valeur avec l’adresse IP « client01 ».

server_address=10.5.5.12

Sur la ligne « allowed_hosts », ajoute l’adresse IP du serveur Nagios « 10.5.5.11 ».

allowed_hosts=127.0.0.1,::1,10.5.5.11

Sauvegarde et ferme.

Ensuite, modifie la configuration « nrpe_local.cfg ».

vim nrpe_local.cfg

Change l’adresse IP par l’adresse IP « client01 » et colle la configuration dans le fichier.

command[check_root]=/usr/lib/nagios/plugins/check_disk -w 20% -c 10% -p /
command[check_ping]=/usr/lib/nagios/plugins/check_ping -H 10.5.5.12 -w 100.0,20% -c 500.0,60% -p 5
command[check_ssh]=/usr/lib/nagios/plugins/check_ssh -4 10.5.5.12
command[check_http]=/usr/lib/nagios/plugins/check_http -I 10.5.5.12
command[check_apt]=/usr/lib/nagios/plugins/check_apt

Sauvegarde et ferme.

Maintenant, redémarre le service NRPE et ajoute-le au démarrage du système.

systemctl restart nagios-nrpe-server
systemctl enable nagios-nrpe-server

Et le serveur Nagios NRPE est en marche.

Installer NRPE

Vérifie le service NRPE à l’aide de la commande suivante.

systemctl status nagios-nrpe-server

Le service NRPE est en place et fonctionne.

Le serveur NRPE est actif et fonctionne

Ensuite, retourne au serveur Nagios et vérifie le serveur NRPE « client01 ».

/usr/lib/nagios/plugins/check_nrpe -H 10.5.5.12
/usr/lib/nagios/plugins/check_nrpe -H 10.5.5.12 -c check_ping

Tu obtiendras le résultat ci-dessous.

Vérifier NRPE

Et tu as installé le serveur Nagios NRPE et les plugins Nagios sur l’hôte « client01 ».

Ajoute la configuration des hôtes au serveur Nagios

De retour au terminal du serveur Nagios, va dans le répertoire « /usr/local/nagios/etc » et crée une nouvelle configuration « server/client01.cfg ».

cd /usr/local/nagios/etc
vim servers/client01.cfg

Change l’adresse IP et le nom d’hôte avec les tiens et colle la configuration dedans.

# Ubuntu Host configuration file1

define host {
        use                          linux-server
        host_name                    client01
        alias                        Ubuntu Host
        address                      10.5.5.12
        register                     1
}

define service {
      host_name                       client01
      service_description             PING
      check_command                   check_nrpe!check_ping
      max_check_attempts              2
      check_interval                  2
      retry_interval                  2
      check_period                    24x7
      check_freshness                 1
      contact_groups                  admins
      notification_interval           2
      notification_period             24x7
      notifications_enabled           1
      register                        1
}

define service {
      host_name                       client01
      service_description             Check Users
      check_command                   check_nrpe!check_users
      max_check_attempts              2
      check_interval                  2
      retry_interval                  2
      check_period                    24x7
      check_freshness                 1
      contact_groups                  admins
      notification_interval           2
      notification_period             24x7
      notifications_enabled           1
      register                        1
}

define service {
      host_name                       client01
      service_description             Check SSH
      check_command                   check_nrpe!check_ssh
      max_check_attempts              2
      check_interval                  2
      retry_interval                  2
      check_period                    24x7
      check_freshness                 1
      contact_groups                  admins
      notification_interval           2
      notification_period             24x7
      notifications_enabled           1
      register                        1
}

define service {
      host_name                       client01
      service_description             Check Root / Disk
      check_command                   check_nrpe!check_root
      max_check_attempts              2
      check_interval                  2
      retry_interval                  2
      check_period                    24x7
      check_freshness                 1
      contact_groups                  admins
      notification_interval           2
      notification_period             24x7
      notifications_enabled           1
      register                        1
}

define service {
      host_name                       client01
      service_description             Check APT Update
      check_command                   check_nrpe!check_apt
      max_check_attempts              2
      check_interval                  2
      retry_interval                  2
      check_period                    24x7
      check_freshness                 1
      contact_groups                  admins
      notification_interval           2
      notification_period             24x7
      notifications_enabled           1
      register                        1
}

define service {
      host_name                       client01
      service_description             Check HTTP
      check_command                   check_nrpe!check_http
      max_check_attempts              2
      check_interval                  2
      retry_interval                  2
      check_period                    24x7
      check_freshness                 1
      contact_groups                  admins
      notification_interval           2
      notification_period             24x7
      notifications_enabled           1
      register                        1
}

Sauvegarde et ferme.

Maintenant, redémarre le serveur Nagios.

systemctl restart nagios

Configurer le client Nagios

Étape 5 – Test

Retourne dans ton navigateur et attends quelques minutes.

Clique sur le menu« Hôtes » et tu verras que le « client01 » a été ajouté.

Tester Nagios

Tu trouveras ci-dessous les détails de la surveillance du serveur « client01 ».

Un autre test de Nagios

Maintenant, tu as ajouté l’hôte à surveiller au serveur Nagios.

Et l’installation de Nagios 4.4.5 sur le serveur Ubuntu 18.04 a été effectuée avec succès.

Référence

Vous aimerez aussi...