Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 22 Jul 2008 10:06:43 -0500
From:      Dan Nelson <dnelson@allantgroup.com>
To:        freebsd-questions@freebsd.org
Cc:        Stephen Allen <sdafreebsduk@rowyerboat.com>
Subject:   Re: Problem running 'top' when ldap is around
Message-ID:  <20080722150642.GG19044@dan.emsphone.com>
In-Reply-To: <447ibec72v.fsf@be-well.ilk.org>
References:  <4885C723.3000708@rowyerboat.com> <447ibec72v.fsf@be-well.ilk.org>

next in thread | previous in thread | raw e-mail | index | archive | help
In the last episode (Jul 22), Lowell Gilbert said:
> Stephen Allen <sdafreebsduk@rowyerboat.com> writes:
> > I've noticed that with "files ldap" in nsswitch.conf, if I try to
> > run "top" and the ldap server is not available, it takes about a
> > minute to start showing information, whereas normally it's
> > instantaneous.
> >
> > The problem seems to be the mapping of uid numbers to usernames
> > (the -u options prevents this).  The man page says:
> >
> > "Normally, top will read as much of the file "/etc/passwd" as is
> > necessary to map all the user id numbers it encounters into login
> > names"
> 
> The man page is misleading.  If LDAP or NIS are present, top seems to
> grab all of the entries from there.  Changes to the man page should
> be submitted upstream, if you're interested in that aspect.
> 
> > So my question is, top must be finding a uid number that it can't
> > match in /etc/passwd, then going on to search ldap.  How can this
> > be?
> 
> I'm not sure that top follows nsswitch.conf (but I didn't spend
> enough time looking to be sure).

It does.  I recommend enabling nscd and editing your nsswitch.conf
passwd and group lines to "files cache ldap".  That way only your first
top invocation will be slow, and the rest will pull from nscd.

-- 
	Dan Nelson
	dnelson@allantgroup.com



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20080722150642.GG19044>