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