facron is a new generation filesystem cron
See http://www.imagination-land.org/posts/2012-12-04-facron-fanotify-cron-system.html and http://www.imagination-land.org/posts/2012-12-07-facron-released.html for more details.
Latest release is 1.1
To build facron:
git clone git://github.com/Keruspe/facron.git
cd facron
./autogen.sh
./configure --sysconfdir=/etc --with-systemdsystemunitdir=/usr/lib/systemd/system
make
sudo make install
facron configuration file is /etc/facron.conf
.
You can put as many entries as you want in this file, one entry per line.
Each line must be formatted like this:
Each time we receive an event matching the fanotify masks on the file path given, the command is launched.
The fanotify masks available are:
FAN_ACCESS
FAN_MODIFY
FAN_CLOSE_WRITE
FAN_CLOSE_NOWRITE
FAN_OPEN
FAN_Q_OVERFLOW
FAN_OPEN_PERM
FAN_ACCESS_PERM
FAN_ONDIR
FAN_EVENT_ON_CHILD
FAN_CLOSE
FAN_ALL_EVENTS
FAN_ALL_PERM_EVENTS
FAN_ALL_OUTGOING_EVENTS
If you configure your fanotify masks like this:
FAN_MODIFY|FAN_CLOSE_WRITE,FAN_OPEN
The event caught will be either FAN_MODIFY
AND FAN_CLOSE_WRITE
, or FAN_OPEN
The command should be an absolute path. You can pass it arguments. If any of your arguments containis sapces, you can surround it with quotes or double quotes. Four special arguments are available:
$@
corresponds to the dirname of your file$#
corresponds to the basename of your file$$
corresponds to the full path of your file$*
corresponds to the process id that accessed the file
Three additional arguments are available which handle a global counter:
$+
increments the counter and returns its new value$-
decrements the counter and returns its new value$=
returns its value
You can reload the configuration at any time by sending a SIGUSR1 to facron:
kill -USR1 $(pidof facron)