On Thu, 2021-05-20 at 22:41 -0400, Gabriel Krisman Bertazi wrote: > Hi, > > This series follow up on my previous proposal [1] to support file > system > wide monitoring. As suggested by Amir, this proposal drops the ring > buffer in favor of a single slot associated with each mark. This > simplifies a bit the implementation, as you can see in the code. I get the need for simplification but I'm wondering where this will end up. I also know kernel space to user space error communication has been a concern for quite a while now. And, from that, there are a couple of things that occur to me. One is that the standard errno is often not sufficient to give sufficiently accurate error reports. It seems to me that, in the long run, there needs to be a way for sub-systems to register errors that they will use to report events (with associated text description) so they can be more informative. That's probably not as simple as it sounds due to things like error number clashes, etc. OTOH that mechanism could be used to avoid using text strings in notifications provided provided there was a matching user space library, thereby reducing the size of the event report. Another aspect, also related to the limitations of error reporting in general, is the way the information could be used. Again, not a simple thing to do or grok, but would probably require some way of grouping errors that are related in a stack like manner for user space inference engines to analyse. Yes, this is very much out of scope but is a big picture long term usefulness type of notion. And I don't know how error storms occurring as a side effect of some fairly serious problem could be handled ... So not really related to the current implementation but a comment to try and get peoples thoughts about where this is heading in the long run. Ian > > As a reminder, This proposal is limited to an interface for > administrators to monitor the health of a file system, instead of a > generic inteface for file errors. Therefore, this doesn't solve the > problem of writeback errors or the need to watch a specific subtree. > > In comparison to the previous RFC, this implementation also drops the > per-fs data and location, and leave those as future extensions. > > * Implementation > > The feature is implemented on top of fanotify, as a new type of > fanotify > mark, FAN_ERROR, which a file system monitoring tool can register to > receive error notifications. When an error occurs a new notification > is > generated, in addition followed by this info field: > > - FS generic data: A file system agnostic structure that has a > generic > error code and identifies the filesystem. Basically, it let's > userspace know something happened on a monitored filesystem. Since > only the first error is recorded since the last read, this also > includes a counter of errors that happened since the last read. > > * Testing > > This was tested by watching notifications flowing from an > intentionally > corrupted filesystem in different places. In addition, other events > were watched in an attempt to detect regressions. > > Is there a specific testsuite for fanotify I should be running? > > * Patches > > This patchset is divided as follows: Patch 1 through 5 are > refactoring > to fsnotify/fanotify in preparation for FS_ERROR/FAN_ERROR; patch 6 > and > 7 implement the FS_ERROR API for filesystems to report error; patch 8 > add support for FAN_ERROR in fanotify; Patch 9 is an example > implementation for ext4; patch 10 and 11 provide a sample userspace > code > and documentation. > > I also pushed the full series to: > > https://gitlab.collabora.com/krisman/linux -b fanotify- > notifications-single-slot > > [1] https://lwn.net/Articles/854545/ > > Cc: Darrick J. Wong <djwong@xxxxxxxxxx> > Cc: Theodore Ts'o <tytso@xxxxxxx> > Cc: Dave Chinner <david@xxxxxxxxxxxxx> > Cc: jack@xxxxxxxx > To: amir73il@xxxxxxxxx > Cc: dhowells@xxxxxxxxxx > Cc: khazhy@xxxxxxxxxx > Cc: linux-fsdevel@xxxxxxxxxxxxxxx > Cc: linux-ext4@xxxxxxxxxxxxxxx > > Gabriel Krisman Bertazi (11): > fanotify: Fold event size calculation to its own function > fanotify: Split fsid check from other fid mode checks > fanotify: Simplify directory sanity check in DFID_NAME mode > fanotify: Expose fanotify_mark > inotify: Don't force FS_IN_IGNORED > fsnotify: Support FS_ERROR event type > fsnotify: Introduce helpers to send error_events > fanotify: Introduce FAN_ERROR event > ext4: Send notifications on error > samples: Add fs error monitoring example > Documentation: Document the FAN_ERROR event > > .../admin-guide/filesystem-monitoring.rst | 52 +++++ > Documentation/admin-guide/index.rst | 1 + > fs/ext4/super.c | 8 + > fs/notify/fanotify/fanotify.c | 80 ++++++- > fs/notify/fanotify/fanotify.h | 38 +++- > fs/notify/fanotify/fanotify_user.c | 213 ++++++++++++++-- > -- > fs/notify/inotify/inotify_user.c | 6 +- > include/linux/fanotify.h | 6 +- > include/linux/fsnotify.h | 13 ++ > include/linux/fsnotify_backend.h | 15 +- > include/uapi/linux/fanotify.h | 10 + > samples/Kconfig | 8 + > samples/Makefile | 1 + > samples/fanotify/Makefile | 3 + > samples/fanotify/fs-monitor.c | 91 ++++++++ > 15 files changed, 485 insertions(+), 60 deletions(-) > create mode 100644 Documentation/admin-guide/filesystem- > monitoring.rst > create mode 100644 samples/fanotify/Makefile > create mode 100644 samples/fanotify/fs-monitor.c >