]> granicus.if.org Git - postgresql/commit
Setup error context callback for transaction lock waits
authorAlvaro Herrera <alvherre@alvh.no-ip.org>
Wed, 19 Mar 2014 18:10:36 +0000 (15:10 -0300)
committerAlvaro Herrera <alvherre@alvh.no-ip.org>
Wed, 19 Mar 2014 18:10:36 +0000 (15:10 -0300)
commitf88d4cfc9d417dac2ee41a8f5e593898e56fd2bd
tree225a86782144a53e83e6083e92df29c8d0785007
parentea8c7e9054abf23fa3de2f8e4414f60ac8a8b620
Setup error context callback for transaction lock waits

With this in place, a session blocking behind another one because of
tuple locks will get a context line mentioning the relation name, tuple
TID, and operation being done on tuple.  For example:

LOG:  process 11367 still waiting for ShareLock on transaction 717 after 1000.108 ms
DETAIL:  Process holding the lock: 11366. Wait queue: 11367.
CONTEXT:  while updating tuple (0,2) in relation "foo"
STATEMENT:  UPDATE foo SET value = 3;

Most usefully, the new line is displayed by log entries due to
log_lock_waits, although of course it will be printed by any other log
message as well.

Author: Christian Kruse, some tweaks by Álvaro Herrera
Reviewed-by: Amit Kapila, Andres Freund, Tom Lane, Robert Haas
src/backend/access/heap/heapam.c
src/backend/access/nbtree/nbtinsert.c
src/backend/catalog/index.c
src/backend/executor/execMain.c
src/backend/executor/execUtils.c
src/backend/replication/logical/snapbuild.c
src/backend/storage/lmgr/lmgr.c
src/include/storage/lmgr.h
src/nls-global.mk