From owner-freebsd-performance@FreeBSD.ORG Mon Jun 12 00:30:36 2006 Return-Path: X-Original-To: performance@FreeBSD.org Delivered-To: freebsd-performance@FreeBSD.ORG Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id D25C416A41F; Mon, 12 Jun 2006 00:30:36 +0000 (UTC) (envelope-from kris@obsecurity.org) Received: from elvis.mu.org (elvis.mu.org [192.203.228.196]) by mx1.FreeBSD.org (Postfix) with ESMTP id 8A42A43D45; Mon, 12 Jun 2006 00:30:36 +0000 (GMT) (envelope-from kris@obsecurity.org) Received: from obsecurity.dyndns.org (elvis.mu.org [192.203.228.196]) by elvis.mu.org (Postfix) with ESMTP id 453E11A3C24; Sun, 11 Jun 2006 17:30:36 -0700 (PDT) Received: by obsecurity.dyndns.org (Postfix, from userid 1000) id F3E15516F6; Sun, 11 Jun 2006 20:30:34 -0400 (EDT) Date: Sun, 11 Jun 2006 20:30:34 -0400 From: Kris Kennaway To: Kris Kennaway Message-ID: <20060612003034.GA37926@xor.obsecurity.org> References: <20060611174527.GA31119@xor.obsecurity.org> <20060611203144.GA34123@xor.obsecurity.org> Mime-Version: 1.0 Content-Type: multipart/signed; micalg=pgp-sha1; protocol="application/pgp-signature"; boundary="0F1p//8PRICkK4MW" Content-Disposition: inline In-Reply-To: <20060611203144.GA34123@xor.obsecurity.org> User-Agent: Mutt/1.4.2.1i Cc: scrappy@FreeBSD.org, performance@FreeBSD.org Subject: Re: Postgresql performance profiling X-BeenThere: freebsd-performance@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Performance/tuning List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Mon, 12 Jun 2006 00:30:37 -0000 --0F1p//8PRICkK4MW Content-Type: text/plain; charset=us-ascii Content-Disposition: inline Content-Transfer-Encoding: quoted-printable On Sun, Jun 11, 2006 at 04:31:44PM -0400, Kris Kennaway wrote: > On Sun, Jun 11, 2006 at 01:45:28PM -0400, Kris Kennaway wrote: > > I set up supersmack against postgresql 8.1 from ports (default config) > > on a 12 CPU E4500. It scales and performs somewhat better than mysql > > on this machine (which is heavily limited by contention between > > threads in a process), but there are a number of obvious performance > > bottlenecks: >=20 > FYI, on a dual p4 + HTT, mysql significantly outperforms pgsql (by > >55% peak performance, probably more if I was using libthr which I > cannot on this machine for technical reasons) on select-key.smack when > configured the same way (i.e. transport over IPv4 instead of local > socket, which supersmack prefers for mysql). >=20 > Contention is still a big issue here (only listing mutexes contended > more than 10% of acquisitions): >=20 > 0 0 142969 0 1996 14458 .101 kern/ker= n_synch.c:218 (Giant) > 0 0 199028 0 11649 27944 .140 kern/ker= n_condvar.c:208 (sellck) > 0 0 400103 0 111216 91336 .228 kern/ker= n_sysctl.c:1317 (Giant) > 0 0 303147 0 108735 131237 .432 i386/i38= 6/trap.c:1005 (Giant) >=20 > I turned off process title setting and got an 8% performance boost. >=20 > Contention is now a bit better but still serious: >=20 > 0 0 22952 0 2067 2521 .109 vm/vm_fa= ult.c:987 (vm object) > 0 0 199153 0 12589 31512 .158 kern/ker= n_condvar.c:208 (sellck) > 0 0 361305 0 124766 130901 .362 i386/i38= 6/trap.c:1005 (Giant) >=20 > i.e. semop() (the Giant-locked syscall) is contending with itself a > lot, and select() is a secondary problem. >=20 > Actually rwatson noticed that semop() is marked MPSAFE, so it's not > clear (but nevertheless true) why Giant is acquired here. OK, pjd > worked out that it's because SYSCALL_MODULE_HELPER() *never* sets the > mpsafe flag, so all such syscalls registered that way (i.e. those > which are part of subsystems that may be loaded from kld) are > Giant-locked regardless of what syscalls.master says. >=20 > I removed the SYSCALL_MODULE_HELPERs from sysv_sem.c but now > postgresql hangs when trying to start; possibly the locking in > sysv_sem.c is just broken since it was never in fact tested. That was my mistake, the syscalls weren't getting registered. I made SYSCALL_MODULE_HELPER add the SYF_MPSAFE flag to work around it instead. The new mutex contention looks like: 0 0 199118 0 12134 30704 .154 kern/kern_= condvar.c:208 (sellck) 0 0 354890 0 100749 110295 .310 kern/sysv_= sem.c:1011 (semid) i.e. semaphores are still contending with themselves. It didn't make any performance difference on this workload, as expected since it was only contending with itself and still is (but in mixed workloads with other Giant activity it will help, of course). Kris --0F1p//8PRICkK4MW Content-Type: application/pgp-signature Content-Disposition: inline -----BEGIN PGP SIGNATURE----- Version: GnuPG v1.4.3 (FreeBSD) iD8DBQFEjLWqWry0BWjoQKURArMtAJwMTP19UbohRLWGvMoKU4pFhdrCNQCeIYcO 7mTKb5txb7l6XmZzE+SRQ54= =6KxN -----END PGP SIGNATURE----- --0F1p//8PRICkK4MW--