From: Sander Smeenk <ssmeenk@freshdot.net>
To: linux-nfs@vger.kernel.org
Subject: rpc.mountd reads /etc/mtab 17028 times, 100% CPU.
Date: Wed, 25 Mar 2015 10:37:07 +0100 [thread overview]
Message-ID: <20150325093707.GC26088@dot.freshdot.net> (raw)
Hi,
I'm running a server that has 1500+ mounted local filesystems.
All of these local filesystems are exported through NFS by this server.
When an NFS-client tries to access one of these exported filesystems,
for example doing a simple 'ls' in a mounted NFS, rpc.mountd on the
server takes 100% CPU and starts to spin over reading /etc/mtab which is
linked to /proc/mounts and totals to about 200KB in size. The client
stalls all the while rpc.mountd is busy reading /etc/mtab for every
filesystem mounted, and then some more.
I made a strace of rpc.mountd during such a run to gather some stats:
# cut -d'(' -f1 straceout.25103 | sort | uniq -c | sort -n
3 fadvise64
6 ioctl
11 lseek
33 readlink
43 select
53 write
809 statfs
814 lstat
1282 stat
17043 mmap
17043 munmap
17088 fstat
17895 open
21728 openat
37295 close
40352 getdents
458616 newfstatat
3763233 read
# grep -c "open.*mtab" straceout.25103
17028
This entire process of reading /etc/mtab 17028 times takes a lot of time
during which the client stalls, but in the end 'it just works fine'.
It just takes ages when you try to tab-complete on a client.
What would be needed to debug and optimise this?
Could someone point me to the code that is involved in doing this?
I'm not a good C-coder but perhaps i can debug more...
Any insights appreciated!
With regards,
-Sander.
--
| Happiness isn't enough for me. I demand EUPHORIA!
| 4096R/20CC6CD2 - 6D40 1A20 B9AA 87D4 84C7 FBD6 F3A9 9442 20CC 6CD2
next reply other threads:[~2015-03-25 9:59 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-03-25 9:37 Sander Smeenk [this message]
2015-03-26 17:00 ` rpc.mountd reads /etc/mtab 17028 times, 100% CPU Steve Dickson
2015-03-27 16:08 ` Sander Smeenk
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=20150325093707.GC26088@dot.freshdot.net \
--to=ssmeenk@freshdot.net \
--cc=linux-nfs@vger.kernel.org \
/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;
as well as URLs for NNTP newsgroup(s).