======== = GLPI = ======== GLPI (acronyme de gestionnaire libre de parc informatique) est un logiciel libre de gestion des services informatiques (ITSM) et de gestion des services d'assistance (Issue Tracking System et ServiceDesk). Cette solution libre est éditée en PHP et distribuée sous licence GPL. GLPI est une application web qui aide les entreprises à gérer leur système d’information. Parmi ses caractéristiques, cette solution est capable de construire un inventaire de toutes les ressources de la société et de réaliser la gestion des tâches administratives et financières. Les fonctionnalités de cette solution aident les Administrateurs IT à créer une base de données regroupant des ressources techniques et de gestion, ainsi qu’un historique des actions de maintenance. La fonctionnalité de gestion d'assistance ou helpdesk fournit aux utilisateurs un service leur permettant de signaler des incidents ou de créer des demandes basées sur un actif ou non, ceci par la création d'un ticket d’assistance. (https://fr.wikipedia.org/wiki/Gestion_libre_de_parc_informatique) Pour une liste des fonctionnalités, voir https://glpi-project.org/fr/fonctionnalites/ Il existe un wiki de documentation en Français (legacy) à l'adresse https://wiki.glpi-project.org/doku.php Sur la machine GLPI, installation de GLPI avec NGINX, PHP et MariaDB ===================================================================== Installation des paquets : # apt install nginx mariadb-server php-fpm # apt install php-mysql php-curl php-gd php-cli php-imap php-ldap php-apcu php-xml php-xmlrpc php-mbstring php-cas php-bz2 php-zip php-intl Sécurisation de MariaDB : # mysql_secure_installation (indiquer un mot de passe 'root' et laisser les réponses par défaut pour le reste) Création d'une base de donnée, d'un utilisateur et du mot de passe associé : ---------------------------------------------------------------------------- Se connecter au serveur de base de données MariaDB : # mysql -u root -p --> après avoir donné le mot de passe, à l'invite de commande mysql, coller chacune des lignes suivantes et appuyer sur 'Enter' : create user postfo2023 identified by 'postfo2023'; create database glpi; grant all privileges on glpi.* to postfo2023; flush privileges; quit; Configuration de NGINX pour GLPI : ---------------------------------- Supprimer le bloc serveur du Virtual Host par défaut : # rm /etc/nginx/sites-enabled/default Créer le bloc serveur pour GLPI : # nano /etc/nginx/sites-enabled/glpi Dans ce fichier, coller le contenu suivant (modifier 'fij.name' si nécessaire) : server { listen 80; listen [::]:80; server_name glpi.fij.name; root /var/www/html; index index.php; access_log /var/log/nginx/glpi.access.log; error_log /var/log/nginx/glpi.error.log; client_max_body_size 100M; autoindex off; location / { try_files $uri $uri/ index.php; } location ~ \.php$ { include snippets/fastcgi-php.conf; fastcgi_pass unix:/var/run/php/php7.4-fpm.sock; include fastcgi_params; fastcgi_intercept_errors on; } location ~ /\.ht { deny all; } } Relancer les services nginx et php-fpm : # systemctl restart nginx # systemctl restart php7.4-fpm Installation de GLPI : ---------------------- Se placer dans l’arborescence du serveur web : # cd /var/www/html/ Télécharger la dernière version de GLPI : # wget https://github.com/glpi-project/glpi/releases/download/9.5.6/glpi-9.5.6.tgz Décompresser l’archive : # tar xzf glpi-9.5.6.tgz Supprimer l’archive téléchargée : # rm glpi-9.5.6.tgz Définir les droits d'accès et le propriétaire du répertoire : # chmod -R u+rwX,go+rX,go-w /var/www/html/glpi/ # chown -R www-data:www-data /var/www/html/glpi/ Ouvrir un navigateur internet et saisir l’url du serveur web : http://glpi.fij.name/glpi ----------------------------------------------------------------------------------------- Suivre les étapes de configuration (ignorer si l'installateur indique que le dossier 'files' n'est pas sécurisé) : 1) Sélectionner la langue, accepter les termes de la licence, cliquer sur 'Installer'. 2) Cliquer sur 'Continuer', saisir les informations concernant les accès à la base de données : Serveur SQL : localhost Utilisateur SQL : postfo2023 Mot de passe SQL : postfo2023 3) Sélectionner la base de données 'glpi'. 4) Cliquer sur 'Continuer' ...vous pouvez décocher la case "Envoyer les statistiques d’usage"... Les identifiants par défaut pour se connecter à l’interface web d'administration de GLPI sont : glpi/glpi Par souci de sécurité : - Changer les mots de passe pour les utilisateurs : glpi, post-only, tech et normal (onglet Administration > Users) - Effacer le fichier install/install.php (rm /var/www/html/glpi/install/install.php) - Vérifier qu'nginx interdit l'accès aux pages : http://glpi.fij.name/glpi/config et http://glpi.fij.name/glpi/files L'installation et la configuration de base de GLPI sont maintenant terminées. Les fonctionnalités d'inventaire : ================================== Pour automatiser l'inventaire d'un parc informatique, le plugin "Fusion Inventory" est souvent utilisé. Un agent est installé sur les machines à inventorier, cet agent est capable de communiquer avec le plugin du serveur GLPI et d'y construire une base de données du parc informatique. L'agent permettra également le déploiement de logiciels sur les machines inventoriées. Pour une liste détaillée des fonctionnalités, voir http://fusioninventory.org/overview/ Installer le plugin Fusion Inventory sur le serveur : ----------------------------------------------------- # wget https://github.com/fusioninventory/fusioninventory-for-glpi/releases/download/glpi9.5%2B3.0/fusioninventory-9.5+3.0.tar.bz2 # tar xjf fusioninventory-9.5+3.0.tar.bz2 Déplacer le dossier 'fusioninventory' dans le dossier 'plugins' de GLPI : # mv fusioninventory/ glpi/plugins/ Effacer l'archive : # rm fusioninventory-9.5+3.0.tar.bz2 Installer et activer le plugin : Dans le menu Setup > Plugins, cliquer sur 'Install'. Ensuite cliquer sur 'Activer le plugin'. Installer l'agent sur des machines clientes : --------------------------------------------- Il est possible d'installer l'agent sur une variété d'OS : Windows, Linux, OS X, BSD, Solaris, AIX, Android, ... Voir http://fusioninventory.org/documentation/installation/ Pour installer l'agent sur FEDORA (l'agent est disponible dans sa dernière version) # dnf install fusioninventory-agent Ensuite éditer le fichier /etc/fusioninventory/agent.cfg : Décommenter et modifier la ligne indiquant l'adresse du serveur GLPI : server = http://glpi.fij.name/glpi/plugins/fusioninventory/ Redémarrer le service : # systemctl restart fusioninventory-agent Pour forcer un inventaire immédiat : # pkill -USR1 -f -P 1 fusioninventory-agent Vérifier dans l'interface web de gestion de GLPI si la machine nouvellement inventoriée s'y trouve. Menu Assets > Computers Parcourir l'inventaire de la machine. Pour installer l'agent sur DEBIAN (essayer sur une des VMs existantes) : Télécharger la dernière version de l'agent : # wget https://github.com/fusioninventory/fusioninventory-agent/releases/download/2.6/fusioninventory-agent_2.6-1_all.deb Installer le paquet téléchargé : # apt install ./fusioninventory-agent_2.6-1_all.deb Editer le fichier de configuration en y indiquant l'url du serveur : # nano /etc/fusioninventory/agent.cfg server = http://glpi.fij.name/glpi/plugins/fusioninventory/ Redémarrer l'agent et forcer l'inventaire immédiat : # systemctl restart fusioninventory-agent # pkill -USR1 -f -P 1 fusioninventory-agent Exercice supplémentaire : ------------------------- Utiliser le module 'Assistance - Helpdesk' de GLPI afin de créer et de gérer des tickets d'assistance : voir http://wiki.glpi-project.org/doku.php?id=fr:manuel:admin:0_index Warning affiché dans l’interface de gestion du serveur GLPI : « GLPI cron not running » : ----------------------------------------------------------------------------------------- Cela indique qu’il faut créer une tâche planifiée pour GLPI : # crontab -u www-data -e (sélectionner « 1. nano » comme éditeur de crontab) Ajouter la ligne : */5 * * * * /usr/bin/php /var/www/html/glpi/front/cron.php &>/dev/null Ceci crée une tâche planifiée pour l’utilisateur système ‘nginx’ (le serveur HTTP) qui lance toutes les 5 minutes l’exécution du fichier « cron.php » de GLPI.