Aller au contenu

Compiler et installer

Effectuez les opérations suivantes sur le serveur. Dans votre environnement, certains paquets dépendants peuvent être manquants. Installez les en utilisant : dnf -y install autoconf automake libtool

[root@Rocky ~]# wget -c https://github.com/inotify-tools/inotify-tools/archive/refs/tags/3.21.9.6.tar.gz
[root@Rocky ~]# tar -zvxf 3.21.9.6.tar.gz -C /usr/local/src/
[root@Rocky ~]# cd /usr/local/src/inotify-tools-3.21.9.6/
[root@Rocky /usr/local/src/inotify-tools-3.21.9.6]# ./autogen.sh && \
./configure --prefix=/usr/local/inotify-tools && \
make && \
make install
...
[root@Rocky ~]# ls /usr/local/inotify-tools/bin/
inotifywait inotifywatch

Ajouter la variable d'environnement PATH, l'écrire dans le fichier de configuration et laisser prendre effet définitivement.

[root@Rocky ~]# vim /etc/profile
...
PATH=$PATH:/usr/local/inotify-tools/bin/
[root@Rocky ~]# . /etc/profile

Pourquoi ne pas utiliser le paquet RPM inotify-tools du dépôt EPEL ? Ou bien procéder avec le code source pour compiler et installer ?

L'auteur estime que la transmission de données à distance est une question d'efficacité, en particulier dans un environnement de production, où il y a un grand nombre de fichiers à synchroniser et un seul fichier peut être particulièrement grand. De plus, la nouvelle version aura quelques corrections de bugs et des extensions de fonctions et peut-être l'efficacité de la transmission de la nouvelle version sera plus élevée, donc l'auteur recommande d'installer inotify-tools par code source. Bien sûr, c'est la préférence personnelle de l'auteur, les utilisateurs sont libres de leur choix.

Ajustement des paramètres du noyau

Vous pouvez ajuster les paramètres du noyau en fonction des besoins de l'environnement de production. Par défaut, il y a trois fichiers dans /proc/sys/fs/inotity/

[root@Rocky ~]# cd /proc/sys/fs/inotify/
[root@Rocky /proc/sys/fs/inotify]# cat max_queued_events ;cat max_user_instances ;cat max_user_watches
16384
128
28014
  • max_queued_events-maximum monitor queue size, default 16384
  • max_user_instances-the maximum number of monitoring instances, the default is 128
  • max_user_watches-the maximum number of files monitored per instance, the default is 8192

Enregistrer certains paramètres dans le fichier /etc/sysctl.conf comme dans les exemples suivants. Ensuite, utilisez sysctl -p pour que les fichiers soient pris en compte

fs.inotify.max_queued_events = 16384
fs.inotify.max_user_instances = 1024
fs.inotify.max_user_watches = 1048576

Commandes associées

L'outil inotify-tools a deux commandes, à savoir :

  • inotifywait : pour une surveillance continue et des résultats de sortie en temps réel. Il est généralement utilisé avec l'outil de sauvegarde incrémentielle rsync. Parce qu'il s'agit d'une surveillance du système de fichiers, il peut être utilisé avec un script. L'auteur présentera plus tard l'implémentation spécifique du script.

  • inotifywatch : pour la surveillance à court terme, affiche les résultats une fois la tâche terminée.

inotifywait a principalement les options suivantes :

-m Surveillance continue
-r Surveillance Recursive
-q Simplifie information de sortie
-e Spécifie le type d'événement des données de surveillance, plusieurs types d'événements sont séparés par des virgules

Les types d'événements sont les suivants :

Type d'événementObservation
accessAccès au contenu d'un fichier ou d'un répertoire
modifierLe contenu du fichier ou du répertoire est enregistré
attribLes attributs du fichier ou du répertoire sont modifiés
close_writeLe fichier ou le répertoire est ouvert en mode écriture puis fermé
close_nowriteLe fichier ou le répertoire est fermé après avoir été ouvert en mode lecture seule
closeIndépendamment du mode lecture/écriture, le fichier ou le répertoire est fermé
openLe fichier ou répertoire est ouvert
moved_toUn fichier ou un répertoire est déplacé vers le répertoire surveillé
moved_fromUn fichier ou un répertoire est déplacé du répertoire surveillé
moveIl y a des fichiers ou répertoires qui sont déplacés ou supprimés du répertoire de surveillance
move_selfLe fichier ou répertoire surveillé a été déplacé
createIl y a des fichiers ou répertoires créés dans le répertoire surveillé
deleteUn fichier ou un répertoire dans le répertoire surveillé est supprimé
delete_selfThe file or directory has been deleted
unmountSystème de fichiers contenant des fichiers ou des répertoires non montés

Exemple : [root@Rocky ~]# inotifywait -mrq -e create,delete /rsync/

Démonstration de la commande inotifywait

Tapez la commande dans le premier terminal pts/0 et, après avoir appuyé sur Entrée, la fenêtre est verrouillée indiquant qu'elle surveille

[root@Rocky ~]# inotifywait -mrq -e create,delete /rsync/

Dans le deuxième terminal pts/1, allez dans le répertoire /rsync/ et créez un fichier.

[root@Rocky ~]# cd /rsync/
[root@Rocky /rsync]# touch inotify

Retour au premier terminal pts/0, les informations de sortie sont les suivantes :

[root@Rocky ~]# inotifywait -mrq -e create,delete /rsync/
/rsync/ CREATE inotify

Combinaison de inotifywait et rsync

Astuce

Nous opérons sur le serveur Rocky Linux 8 en utilisant le protocole SSH pour la démonstration.

Pour l'authentification sans mot de passe du protocole SSH, veuillez vous référer à cet article. Un exemple du contenu d'un script bash est le suivant. Vous pouvez ajouter différentes options après la commande en fonction de vos besoins. Par exemple, vous pouvez ajouter --delete après la commande rsync.

#!/bin/bash
a="/usr/local/inotify-tools/bin/inotifywait -mrq -e modify,move,create,delete /rsync/"
b="/usr/bin/rsync -avz /rsync/* testfedora@192.168.100.5:/home/testfedora/"
$a | while read directory event file
    do
        $b &>> /tmp/rsync.log
    done
[root@Rocky ~]# chmod +x rsync_inotify.sh
[root@Rocky ~]# bash /root/rsync_inotify.sh &

Astuce

Lors de l'utilisation du protocole SSH pour la transmission de la synchronisation des données, si le port de service SSH de la machine cible n'est pas 22, vous pouvez utiliser une méthode similaire à cela —— b="/usr/bin/rsync -avz -e 'ssh -p [port-number]' /rsync/* testfedora@192. 68.100.5:/home/testfedora/"

Astuce

Si vous voulez lancer automatiquement ce script au démarrage [root@Rocky ~]# echo "bash /root/rsync_inotify. h &" >> /etc/rc.local [root@Rocky ~]# chmod +x /etc/rc.local

Si vous utilisez le protocole rsync pour la synchronisation, vous devez configurer le service rsync de la machine cible, veuillez vous référer à rsync demo 02, fichier de configuration rsync, connexion rsync automatique

Author: tianci li

Contributors: Steven Spencer, Ganna Zhyrnova