On Tue, Jan 04, 2005 at 09:27:27PM -0500, Bruce Campbell wrote:
> I wrote a small program:
>
> #include <sys/types.h>
> #include <pwd.h>
>
> main( int argc, char *argv[] )
> {
> getpwuid( 13076 );
> }
>
> and ran it under truss on 5.x and it generated 178,711 lines of output.
> (the bulk of which is those lseek/read calls as above)
>
> 4.7 (with same master.passwd file) gave 59 lines of output, which seems
> normal.
>
> I'm speculating that imap and sendmail and just about everything use
> getpwuid and getpwuid is misbehaving on 5.x especially with a large
> master.passwd file.
Try tuning the pwd_mkdb parameters (see hash(3)) in
/usr/src/usr.sbin/pwd_mkdb/pwd_mkdb.c and recompile:
HASHINFO openinfo = {
4096, /* bsize */
32, /* ffactor */
256, /* nelem */
2048 * 1024, /* cachesize */
NULL, /* hash() */
0 /* lorder */
};
e.g. adjust nelem to 12000 to accomodate your
significantly-larger-than-average password database. If this helps,
please submit a PR requesting that someone make an option to pwd_mkdb
to tune this at runtime (or better yet, submit the patch to do this
yourself - it's straightforward to modify the source to do this).
Kris
pgpAjUrFD81hG.pgp
Description: PGP signature
