File: poll.md

package info (click to toggle)
mtail 3.2.24-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 7,384 kB
  • sloc: yacc: 647; makefile: 226; sh: 78; lisp: 77; awk: 17
file content (60 lines) | stat: -rw-r--r-- 2,676 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
# Polling filesystem watcher

Original date: 2018-08-13
Status: obsolete
Last Updated: 2020-11-17

## Overview

Implement a hybrid polling and notify based filesystem watcher.

## Background

Tracking issue #169

`mtail` has a filesystem watcher which is used to watch the state of programme
files and log files; if they change, then programmes are reloaded and log files
are read.  `mtail` uses the [fsnotify](https://github.com/fsnotify/fsnotify)
package to implement the filesystem watcher.  fsnotify, which uses the
`inotify(7)` system in Linux, lets `mtail` offload the work of polling the
filesystem for changes to one where it is notified by the kernel instead,
reducing the amount of work done.

Some users want a polling option instead of fsnotify as their platforms don't
support fsnotify, e.g. mipsel (bug in fsnotify) or no kernel support? (using on
AIX).

This design attempts to determine how to support a hybrid watcher.

To the best of our ability, users should not have to configure poll- or fsnotify-based filesystem watching.

From Linux's inotify(7):

       Inotify  reports  only events that a user-space program triggers through the filesystem API.  As a result,
       it does not catch remote events that occur on  network  filesystems.   (Applications  must  fall  back  to
       polling  the  filesystem  to  catch  such events.)  Furthermore, various pseudo-filesystems such as /proc,
       /sys, and /dev/pts are not monitorable with inotify.

## design ideas

fsnotify watch add error, fallback to poll.  How does fsnotify report errors about watches not being supported?  E.g on NFS or with AIX?

poll implemented similar to fsnotify poll loop?  if that, will that be duplicated work?  Do we care enough to avoid nested polling loops?  should this be pushed upstream?

how to let users override the choice?  Argument listing poll-only filesystem path prefixes?

Could poll be on by default for all files, with a timeout if no events have been received from inotify in some timeout?  This could be tricky, we don't need to poll files that are inotified.  But, again from inotify(7):

       Note that the event queue can overflow.  In this case, events are lost.  Robust applications should handle
       the possibility of lost events gracefully.  For example, it may be necessary to rebuild part or all of the
       application cache.  (One simple, but possibly expensive, approach is to close the inotify file descriptor,
       empty the cache, create a new inotify file descriptor, and then re-create watches and  cache  entries  for
       the objects to be monitored.)


## references

https://github.com/fsnotify/fsnotify

inotify(7)