Lassen Sie sich inotifizieren, um ein In_Unmount -Ereignis ordnungsgemäß abzugeben

StackOverflow https://stackoverflow.com/questions/5360238

  •  27-10-2019
  •  | 
  •  

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?

War es hilfreich?

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 ...

Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow
scroll top