Linux

CentOS 5.3

inotify(7)


INOTIFY

NOM

inotify − Surveillance d’événements sur le système de fichier.

DESCRIPTION

L’API inotify fournit un mécanisme pour la surveillance d’événements sur le système de fichiers. Inotify peut être utilisé pour surveiller des fichiers individuels ou pour surveiller des répertoires. Lorsqu’un répertoire est surveillé, inotify renverra les événements du répertoire lui-même et des fichiers qu’il contient.

Les appels système suivants sont utilisés avec cette API : inotify_init(), inotify_add_watch(), inotify_rm_watch(), read() et close().

inotify_init(2) crée une instance inotify et renvoie un descripteur de fichier faisant référence à une instance inotify.

inotify_add_watch(2) manipule une « liste de surveillance » associée à une instance inotify. Chaque élément (« surveillant ») de la liste de surveillance spécifie le nom du chemin d’un fichier ou d’un répertoire, avec un ensemble d’événements que le noyau doit surveiller pour le fichier référencé par ce nom de chemin. inotify_add_watch() peut soit créer un nouvel élément surveillant, soit modifier un élément existant. Chaque surveillant a un « descripteur de surveillant » unique, un entier renvoyé par inotify_add_watch() lorsque le surveillant est créé.

inotify_rm_watch(2) supprime un élément d’une liste de surveillance inotify.

Lorsque tous les descripteurs de fichier référençant une instance inotify ont été fermés, l’objet sous-jacent et ses ressources sont libérés afin de pouvoir être réutilisés par le noyau ; tous les surveillants associés sont automatiquement libérés.

Pour déterminer quels événements sont survenus, une application lit (read(2)) le descripteur de fichier. Si aucun événement n’est survenu, en supposant que l’on ait un descripteur de fichier bloquant, une lecture (read(2)) bloquera jusqu’à ce qu’au moins un événement survienne.

Chaque lecture réussie renvoie un tampon contenant une ou plusieurs structures comme la suivante :

struct inotify_event {
    int      wd;       /* Descripteur de surveillant */
    uint32_t mask;     /* Masque d’événement */
    uint32_t cookie;   /* Cookie unique associant des événements
                          en relation (pour rename(2)) */
    uint32_t len;      /* Taille du champ ’name’ */
    char     name[];   /* Nom optionnel terminé par un octet nul */
};

wd identifie le surveillant pour lequel survient cet événement. C’est l’un des descripteurs de surveillant renvoyés par un précédent appel à inotify_add_watch().

mask contient des bits qui décrivent l’événement qui est survenu (voir plus loin).

cookie est un entier unique qui connecte les événements en relation. Actuellement, il n’est utilisé que pour renommer les événements permettant à la paire résultante des événements IN_MOVE_FROM et IN_MOVE_TO d’être connectée par l’application.

Le champ name n’est présent que lorsqu’un événement est renvoyé pour un fichier appartenant au répertoire surveillé ; il identifie le chemin relatif du fichier dans le répertoire surveillé. Le nom du chemin est terminé avec un octet nul et peut inclure d’autres octets nuls pour aligner les lectures ultérieures sur une frontière d’adresse convenable.

Le champ len totalise tous les octets de name, y compris les octets nuls ; la longueur de chaque structure inotify_event est donc sizeof(inotify_event)+len.

Ãvénements inotify

L’argument mask de inotify_add_watch(2) et le champ mask de la structure inotify_event renvoyée lors de la lecture (read(2)) d’un descripteur de fichier inotify sont tous les deux des masques de bits qui identifient les événements inotify. Les bits suivants peuvent être spécifiés dans mask lors d’un appel à inotify_add_watch() et être renvoyés dans le champ mask lors d’un appel à read() :

Lors de la surveillance d’un répertoire, les événements précédents marqués d’un astérisque (*) peuvent survenir pour des fichiers appartenant au répertoire, auquel cas le champ name dans la structure inotify_event renvoyée identifie le nom du fichier dans le répertoire.

La macro IN_ALL_EVENTS est définie comme un masque de bits de tous les événements précédents. Cette macro peut être utilisée comme argument mask lors d’un appel à inotify_add_watch().

Il y a deux autres macros bien pratiques : IN_MOVE qui est équivalente à IN_MOVED_FROM|IN_MOVED_TO, et IN_CLOSE qui est équivalente à IN_CLOSE_WRITE|IN_CLOSE_NOWRITE.

Les bits supplémentaires suivants peuvent également être spécifiés dans mask lors d’un appel à inotify_add_watch() :

Les bits suivants peuvent être positionnés dans le champ mask renvoyé par read() :

Interfaces /proc

Les interfaces suivantes peuvent être utilisées pour limiter la quantité de mémoire noyau consommée par inotify :

/proc/sys/fs/inotify/max_queued_events

La valeur dans ce fichier est utilisée lorsqu’une application appelle inotify_init(2) pour définir une limite haute du nombre d’événements qui peuvent être mis en file d’attente dans l’instance inotify correspondante. Les événement en excès sont rejetés mais l’événement IN_Q_OVERFLOW est toujours généré.

/proc/sys/fs/inotify/max_user_instances

Spécifie la limite haute du nombre d’instances inotify qui peuvent être crées par UID réel.

/proc/sys/fs/inotify/max_user_watches

Spécifie une limite sur le nombre de surveillants qui peuvent être associés à chaque instance inotify.

NOTES

Les descripteurs de fichiers inotify peuvent être surveillés avec select(2), poll(2) et epoll(7).

Si des événements inotify successifs produits sur un descripteur de fichier inotify sont identiques (mêmes wd, mask, cookie et name), ils sont fusionnés en un seul événement.

Les événements renvoyés par une lecture sur un descripteur de fichier inotify forment une file ordonnée. Ainsi, par exemple, il est garanti que si un répertoire est renommé, les événements seront produits dans le bon ordre sur le descripteur de fichier inotify.

L’ioctl() FIONREAD renvoie le nombre d’octets disponibles à la lecture sur un descripteur de fichier inotify.

La surveillance inotify sur les répertoires n’est pas récursive : pour surveiller les sous-répertoires d’un répertoire, vous devez créer des surveillants supplémentaires.

VERSIONS

Inotify a été fusionné au noyau Linux 2.6.13. Les interfaces bibliothèque nécessaires ont été ajoutées à la glibc dans la version 2.4.

BOGUES

Dans les noyaux précédant le 2.6.16, l’attribut IN_ONESHOT de mask ne fonctionnait pas.

Jusqu’à la glibc 2.4, les définitions de IN_DONT_FOLLOW, IN_MASK_ADD est IN_ONLYDIR étaient absentes de <sys/inotify.h>.

CONFORMITÃ

Cet appel système est spécifique à Linux.

VOIR AUSSI

inotify_add_watch(2), inotify_init(2), inotify_rm_watch(2), read(2), stat(2), Documentation/filesystems/inotify.txt.

TRADUCTION

Ce document est une traduction réalisée par Alain Portal <aportal AT univ-montp2 DOT fr> le 21 juillet 2006 et révisée le 10 août 2006.

L’équipe de traduction a fait le maximum pour réaliser une adaptation française de qualité. La version anglaise la plus à jour de ce document est toujours consultable via la commande : « LANG=en man 7 inotify ». N’hésitez pas à signaler à l’auteur ou au traducteur, selon le cas, toute erreur dans cette page de manuel.


inotify(7)