system slowdown - vnode related
Tadaaki Nagao
nagao at iij.ad.jp
Tue Jun 10 12:38:15 PDT 2003
Hi there,
In "Re: system slowdown - vnode related",
David Schultz <das at freebsd.org> wrote:
> On Mon, Jun 09, 2003, Masachika ISHIZUKA wrote:
> > Hi, David-san.
> > I have still vnodes problem in 4.8-stable with /sys/kern/vfs_subr.c
> > 1.249.2.30.
> >
> > 310.locate of weekly cron make slow down or panic. Values of sysctl
> > are shown as follows when they reached slow down.
> >
> > (1) #1 machine (Celeron 466 with 256 mega byte rams)
> >
> > % sysctl kern.maxvnodes
> > kern.maxvnodes: 17979
> > % sysctl vm.zone | grep VNODE
> > VNODE: 192, 0, 18004, 122, 18004
>
> This looks pretty normal to me for a quiescent system. Ordinarily
> I would actually suggest raising maxvnodes if you have lots of
> little files. Does the number of vnodes shoot up when 310.locate
> runs? Did you get a backtrace from the panics? Perhaps the VM
> page cache is still interfering...
Excuse me for jumping in, but I just happened to see hangs on machines
at a company I'm working for (though no panic in my case), and I have
something I'd like to ask Ishizuka-san for trying.
Ishizuka-san, could you possibly try the following command line
repeatedly while slowdown is being observed?
% vmstat -m | grep '^ *vfscache'
If the third number of its output is approaching or hitting the fourth,
the chances are your kernel is running out of memory for namecache,
which was actually the case on my machines.
And if it is the case for you, Ishizuka-san, try setting debug.vfscache
to 0 to disable namecache entirely and see if your problem completely
goes away (probably at the cost of performance, though).
-*- -*-
In fact, I've been reading some of the kernel source and tracking down
the cause of my case for these two weeks, and it seems that I found
something. Though I may be wrong, but I thought describing it here was
better than nothing, and so the following goes the thing I think I've
found:
There seems to be a senario where the memory area for namecache
(M_VFSCACHE) is exhausted while the number of vnodes is too small to
hit the limit (maxvnodes).
More specifically, it seems that when a lot of hard links are being
accessed, some of VDIR vnodes can have an exceedingly bunch of
namecache entries pointing to only a few VREG vnodes of hard-linked
files, which can result in exhaustion of the memory area for
M_VFSCACHE while the total number of vnodes in the kernel might not
increase too much to hit maxvnodes.
And then, if you luckily have enough total memory in the kernel, the
exhaustion of the area for M_VFSCACHE doesn't necessarily cause a
panic, but causes the process traversing those links to be blocked (in
the malloc(9) call in sys/kern/vfs_cache.c:cache_enter()).
After that, what you'll observe is almost everything you try in
userland is blocked though the kernel responds to a ping(8), because
any process will be blocked when attempting to create a namecache
entry.
As I've said I, not being a VFS expert, may be wrong, but I'd be more
than happy if this helps someone who knows much about this part of the
kernel track down the problem.
Thanks,
Tadaaki Nagao <nagao at iij.ad.jp>
Applied Technology Division, Internet Initiative Japan Inc.
More information about the freebsd-stable
mailing list