]> granicus.if.org Git - postgresql/commit
Use group updates when setting transaction status in clog.
authorRobert Haas <rhaas@postgresql.org>
Thu, 9 Mar 2017 22:44:52 +0000 (17:44 -0500)
committerRobert Haas <rhaas@postgresql.org>
Thu, 9 Mar 2017 22:49:01 +0000 (17:49 -0500)
commitccce90b398673d55b0387b3de66639b1b30d451b
treea67a266ca479af316b636b09482426fcacf2e834
parentf077e1b2e374fadc443b6aa9fa54ad9bb6f908c7
Use group updates when setting transaction status in clog.

Commit 0e141c0fbb211bdd23783afa731e3eef95c9ad7a introduced a mechanism
to reduce contention on ProcArrayLock by having a single process clear
XIDs in the procArray on behalf of multiple processes, reducing the
need to hand the lock around.  Use a similar mechanism to reduce
contention on CLogControlLock.  Testing shows that this very
significantly reduces the amount of time waiting for CLogControlLock
on high-concurrency pgbench tests run on a large multi-socket
machines; whether that translates into a TPS improvement depends on
how much of that contention is simply shifted to some other lock,
particularly WALWriteLock.

Amit Kapila, with some cosmetic changes by me.  Extensively reviewed,
tested, and benchmarked over a period of about 15 months by Simon
Riggs, Robert Haas, Andres Freund, Jesper Pedersen, and especially by
Tomas Vondra and Dilip Kumar.

Discussion: http://postgr.es/m/CAA4eK1L_snxM_JcrzEstNq9P66++F4kKFce=1r5+D1vzPofdtg@mail.gmail.com
Discussion: http://postgr.es/m/CAA4eK1LyR2A+m=RBSZ6rcPEwJ=rVi1ADPSndXHZdjn56yqO6Vg@mail.gmail.com
Discussion: http://postgr.es/m/91d57161-d3ea-0cc2-6066-80713e4f90d7@2ndquadrant.com
src/backend/access/transam/clog.c
src/backend/access/transam/twophase.c
src/backend/storage/lmgr/proc.c
src/include/access/twophase.h
src/include/storage/proc.h