From: Niklas Cassel <niklas.cassel@axis.com>
To: amir73il@gmail.com, mszeredi@redhat.com
Cc: linux-unionfs@vger.kernel.org, linux-kernel@vger.kernel.org
Subject: overlayfs non-persistent inodes
Date: Sat, 13 Jan 2018 01:19:03 +0100 [thread overview]
Message-ID: <20180113001902.GA10063@axis.com> (raw)
Hello Miklos, Amir
We are having some problems with inotify + overlayfs.
If we start to monitor a directory on an overlayfs,
and get into a low memory situation, or if
/proc/sys/vm/drop_caches is called explicitly,
our inotify stops reporting events.
This appears to be caused by non-persistent inodes.
Looking at the commits, it looked like inode numbers
were persistent since commit
b7a807dc2010 ("ovl: persistent inode number for directories").
However, this doesn't seem to take different file systems
into account:
# cat /proc/version
Linux version 4.15.0-rc7-next-20180109-00003-gd1acc32c9ee5 (niklass@lnxartpec1)
(gcc version 6.3.0 (crosstool-NG crosstool-ng-1.22.0-610-g21cde94)) #74
SMP Fri Jan 12 13:23:57 CET 2018
# mkdir -p /test/dir /mnt/tmp
# mount -t tmpfs tmpfs /mnt/tmp
# mkdir /mnt/tmp/.work-test /mnt/tmp/test
# mount -t overlay overlay /test -o lowerdir=/test,upperdir=/mnt/tmp/test,
workdir=/mnt/tmp/.work-test
# ls -lid /test/dir
6313 drwxr-xr-x 2 root root 40 Jan 1 00:01 /test/dir
# echo 3 > /proc/sys/vm/drop_caches
[ 229.762380] sh (118): drop_caches: 3
# ls -lid /test/dir
6318 drwxr-xr-x 2 root root 40 Jan 1 00:01 /test/dir
There are probably a few user space applications that
rely on inotify. If inotify suddenly and silently stops
reporting events after some memory pressure, all kinds
of bugs could be introduced in user space.
I'm guessing that it will not be so easy to figure out
that overlayfs might be the root-cause of their
seemingly random bug.
Regards,
Niklas
next reply other threads:[~2018-01-13 0:19 UTC|newest]
Thread overview: 2+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-01-13 0:19 Niklas Cassel [this message]
2018-01-13 4:38 ` overlayfs non-persistent inodes Amir Goldstein
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20180113001902.GA10063@axis.com \
--to=niklas.cassel@axis.com \
--cc=amir73il@gmail.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-unionfs@vger.kernel.org \
--cc=mszeredi@redhat.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox