I am experiencing lock contention on one single UPDATE statement at a
certain time in whole day. This is a small table to UPDATE.
My suspect is we are facing it for one specific ID.
Could you please let me know how can I identify the tuple.

I got a log like follows:
          blocker_target           | blocker_pid | blocker_mode  | depth |
             target               | pid  |     mode      |    seq
-----------------------------------+-------------+---------------+-------+-----------------------------------+------+---------------+-----------
 (tuple,475999,662775,1988,6,,,,,) |        3557 | ExclusiveLock |     1 |
(tuple,475999,662775,1988,6,,,,,) | 3543 | ExclusiveLock | 3557,3543
 (tuple,475999,662775,1988,6,,,,,) |        3557 | ExclusiveLock |     1 |
(tuple,475999,662775,1988,6,,,,,) | 7387 | ExclusiveLock | 3557,7387

Any idea on it.

Thanks.


On Thu, Jul 17, 2014 at 12:40 PM, Douglas J Hunley <doug.hun...@gmail.com>
wrote:

> On Thu, Jul 17, 2014 at 3:34 PM, AI Rumman <rumman...@gmail.com> wrote:
>
>> Hi,
>>
>> I have been facing lock contention in my Postgresql 9.1 DB.
>> And when I am querying in the pg_locks table I found a lock type with
>> transactionid.
>> Could someone please tell me what it means?
>>
>> Thanks.
>>
>
> from http://www.postgresql.org/docs/9.3/static/view-pg-locks.html :
> Every transaction holds an exclusive lock on its virtual transaction ID
> for its entire duration. If a permanent ID is assigned to the transaction
> (which normally happens only if the transaction changes the state of the
> database), it also holds an exclusive lock on its permanent transaction ID
> until it ends. When one transaction finds it necessary to wait specifically
> for another transaction, it does so by attempting to acquire share lock on
> the other transaction ID (either virtual or permanent ID depending on the
> situation). That will succeed only when the other transaction terminates
> and releases its locks.
>
> I believe that describes what you're seeing
>
> --
> Douglas J Hunley (doug.hun...@gmail.com)
>

Reply via email to