Il est d’usage lorsque l’on compile soi-même Nagios de tout installer dans /usr/local/nagios. Le principal avantage de cette installation par défaut est qu’il n’y a en général rien à éditer dans les fichiers de configuration de Nagios et surtout des addons, ceux-ci étant prévus pour fonctionner par défaut dans cette arborescence. Elle est donc particulièrement adaptée aux débutants.
Pourtant, même si cette installation par défaut est tout à fait valable, elle ne correspond plus aux standards actuels tels que définis par la Linux Standard Base ( LSB) et ne permet pas de construire une solution de supervision contenant Nagios en son cœur mais pas que Nagios. C’est le cas de la plupart des installations où Nagios est complété au minimum par NRPE, NSCA, et un module grapheur type PNP. Nous allons donc poser les bases d’une telle installation plutôt réservée il est vrai à des administrateurs Nagios expérimentés.
L’arborescence par défaut a sa racine dans /usr/local/nagios/ comme le montre le schéma ci-dessous
Six dossiers se trouvent présents sous cette racine.
Voici un fichier exhaustif de tous les fichiers et répertoires installés par Nagios obtenu par une simple commande
ls -lR
sur le répertoire /usr/local/nagios/ ainsi que le fichier source au format freemind ayant servi à composer l’image ci-dessus.
L’installation qui est proposée dans la suite de ce document permet de :
Nous allons installer l’ensemble de notre solution de supervision dans /opt/monitoring/. Cette solution contiendra les logiciels Nagios, NRPE, NSCA, PNP, SEC, Collectd et NDOUtils.
Le schéma ci-dessous illustre cette arborescence d’installation néanmoins amputé du dossier etc/ que nous verrons plus loin.
Pas de révolution par rapport à une installation par défaut mais quelques points à souligner :
Cette arborescence est bien entendu une base que vous avez tout loisir de modifier en fonction de vos goûts personnels ou de vos propres standards d’entreprise. Passons au gros morceau avec l’arborescence des fichiers de configuration.
Les fichiers de configuration contiennent l’ensemble des informations nécessaires à la prise en compte d’un périmètre de supervision par Nagios. Il est donc logique d’y trouver des notions d’hôtes, de services, de contacts, de notifications, d’escalades, de dépendances, de groupes, de gabarits et de périodes de temps qui sont autant d’objets que Nagios reconnaît et manipule. Bien que Nagios soit fourni en standard avec un jeu de fichiers de configuration d’exemple, l’arborescence choisie pour ces fichiers se révèlent vite inconfortable et sommaire dès que le périmètre supervisé augmente. Et comme toujours avec Nagios, on se retrouve avec une liberté totale de faire ce qu’on veut; y compris des bêtises.
Nous allons voir à l’aide du schéma ci-dessous quelques bonnes pratiques qui peuvent servir de sources d’inspiration pour votre propre arborescence de fichiers de configuration.
Avant de rentrer dans quelques explications sur cette arborescence, voyons en les points forts 1)
Pour cela, rendez-vous dans le dossier /opt/monitor/etc/nagios/. Ce dossier contient l’ensemble des fichiers de configuration nécessaires au bon fonctionnement de Nagios. Au premier niveau, nous retrouvons les traditionnels fichiers nagios.cfg, resource.cfg, cgi.cfg mais aussi deux petits nouveaux : le fichier htpassword.users et le fichier apache2.cfg. le premier sert à stocker les utilisateurs et mots de passe servant à l’interface web de Nagios et le fichier apache2.cfg comprend la configuration Apache pour Nagios. Il faudra faire un lien symbolique vers ce fichier depuis /etc/apache2/conf.d/ pour qu’il soit pris en compte par Apache.
Le dossier le plus important, celui qui contiendra l’ensemble de vos objets de configuration pour Nagios est le dossier conf.d/… Reprenez en cœur avec moi : Comme à la sauce Debian
Dans un environnement simple, vous pouvez vous passer des dossiers global/, default/, local/ et specific/. Il contiennent la même arborescence et seront utilisés plus loin pour un environnement distribué. Dans un environnement, depuis le répertoire conf.d./, vous pointez directement sur les répertoires situés dans un des dossiers cités plus haut. Le découpage est alors très simple. Un dossier parent par type d’objets manipulés par Nagios (hosts/, services/, contacts/,etc…). Chacun des ces dossiers peut être scindés à l’envie ou au besoin en autant de sous répertoires. par exemple, vous avez des hôtes Windows et des hôtes Linux, créez alors un sous répertoire hosts/linux/ et hosts/windows/. Chacun de ces dossiers contient les déclarations d’hôtes genre www.monitoring-fr.org.cfg dans le dossier hosts/linux/.
Le meilleur pour la fin, mais aussi le plus complexe mais pas trop quand même. Nous avons vu en environnement simple de quoi pouvait être composé l’un des dossiers global/ ou local/, etc… Mais à quoi servent ces dossiers que nous avons superbement ignorés jusqu’ici ?
En environnement distribué, il y a au moins trois serveurs Nagios; un central et des collecteurs 2). Ces dossiers vont servir à stocker les configurations de chacun de ces serveurs Nagios. Cela permet d’avoir l’ensemble des configurations de serveurs en un seul point (qui est versionné je le rappelle) et d’ensuite distribuer les objets de configurations en fonction des serveurs.
Chacun de ces dossiers contient l’arborescence vu plus haut; à savoir hosts/, services/, etc… Ce découpage, s’il paraît complexe au premier abord permet de pouvoir gérer n’importe quel objet de configuration en fonction du périmètre auquel il s’applique. Cela permet d’avoir des exceptions de n’importe quel ordre comme un collecteur ne supervisant son périmètre que de telle heure à telle heure. Tout est possible comme désactiver un objet de configuration sans l’enlever de la configuration. Il suffit de renommer le fichier objet_de_configuration.cfg en objet_de_configuration.no ou n’importe quelles extension qu’il vous plaira pour que ce fichier soit ignoré au prochain redémarrage de Nagios. Vous pouvez aussi l’effacer puisqu’il pourra renaître de ses cendres grâce au contrôle de révision mis en place sur le répertoire parent.
Nous sommes loin d’avoir fait le tour des possibilités et liberté offertes par Nagios en matière d’arborescence de fichiers et plus spécialement de fichiers de configuration. Les pistes évoquées ici permettent simplement de structurer sa solution de supervision pour une administration au quotidien plus puissante et plus sûre. Libre à vous d’adapter l’ensemble de ce document à vos goûts; l’essentiel étant de ne pas rater la phase de réflexion sur la gestion de ces fichiers de configuration. Le fichier source ayant servi à construire les illustrations de ce document peut vous servir de point de départ.