Lassen Sie sich inotifizieren, um ein In_Unmount -Ereignis ordnungsgemäß abzugeben
Frage
Hallo, ich habe versucht, inotifiziert zu werden, um ein IN_Unmount -Ereignis zu erzielen, aber es ist überhaupt nicht mit mir zusammengearbeitet, also habe ich ein einfaches Experiment mit InotifyWait gemacht. Dies ist das Ergebnis unten:
paul@imaskar ~ $ inotifywait -r /storage/test/ -m
Setting up watches. Beware: since -r was given, this may take a while!
Watches established.
/storage/test/ CREATE,ISDIR a
/storage/test/ OPEN,ISDIR a
/storage/test/ CLOSE_NOWRITE,CLOSE,ISDIR a
/storage/test/ DELETE,ISDIR a
/storage/test/a/ DELETE_SELF
/storage/test/a/ IGNORED
/storage/test/ IGNORED
Grundsätzlich wird es alle anderen Ereignisse wie Erstellen, Öffnen usw. aufnehmen. /Speicher/Test/ es wird a aussagen Ignoriert Für alle Uhren, die es geschaffen hatte, aber es gibt nie ein Unmontalereignis aus ...
Es scheint also, als ob ich kein In_Unmount -Ereignis erhalten kann, aber die gesamte Inotify -Dokumentation, die ich gelesen habe, besagte, dass der Kernel dem Ereignis eine IN_Unmount -Bitflag hinzufügen wird, wenn ein überwachtes Speicher der Datei-/Verzeichnis -Backing -Speicher unmontiert wurde ...
Hier ist ein einfacher C -Code von - Patch inotifizieren
#include <stdio.h>
#include <stdlib.h>
#include <sys/inotify.h>
int main(int argc, char **argv)
{
char buf[1024];
struct inotify_event *ie;
char *p;
int i;
ssize_t l;
p = argv[1];
i = inotify_init();
inotify_add_watch(i, p, ~0);
l = read(i, buf, sizeof(buf));
printf("read %d bytes\n", l);
ie = (struct inotify_event *) buf;
printf("event mask: %x\n", ie->mask);
return 0;
}
Wie auch immer, ich habe die folgenden Schritte durchgeführt:
gcc -oinotify inotify.c
mkdir mnt
sudo mount -ttmpfs none mnt
mkdir mnt/d
./inotify mnt/d/
# Different shell
sudo umount mnt
Und schließlich hier ist es, was es emittiert
read 16 bytes
event mask: 8000
Zu diesem Zeitpunkt bin ich mir also nicht sicher, ob das Problem im Code oder etwas anderes liegt?
Lösung
Dies scheint ein Kernel -Fehler zu sein, der gemäß dem festgelegt wurde Lkml. Ungefähr da Kernel 2.6.31 das In_Unmount-Ereignis nicht gesendet wurde, wenn Inodes umgebracht werden ... war dieser Patch für "34-Longterm" -Kernel 2.6.35 (?).
Wie auch immer, ich konnte auf Kernel 2.6.37 aufrüsten und die oben genannten Tests erneut durchführen, und hier sind die Ergebnisse:
mkdir mnt
sudo mount -ttmpfs none mnt
mkdir mnt/d
inotifywait -r mnt/d/ -m
# Different shell
sudo umount mnt
Und hier ist die Ausgabe:
Setting up watches. Beware: since -r was given, this may take a while!
Watches established.
/tmp/test/d/ UNMOUNT
/tmp/test/d/ IGNORED
/tmp/test/ UNMOUNT
/tmp/test/ IGNORED
Und gemäß dem Beispiel -C -Code ist hier die Ausgabe:
read 32 bytes
event mask: 2000
Und wenn Sie sich die Headers inotify.h ansehen, ist dies die richtige Ereignismaske für die Flagge in_unmount, so dass es endlich ~ 2,6.35 oder letztere ...