From: | Craig James <craig_james(at)emolecules(dot)com> |
---|---|
To: | Scott Marlowe <scott(dot)marlowe(at)gmail(dot)com> |
Cc: | pgsql-admin(at)postgresql(dot)org |
Subject: | Re: Deadlock on "select ... for update"? |
Date: | 2011-11-30 18:08:42 |
Message-ID: | 4ED6712A.8040603@emolecules.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-admin |
On 11/29/11 10:36 AM, Scott Marlowe wrote:
> On Tue, Nov 29, 2011 at 11:15 AM, Craig James
> <craig_james(at)emolecules(dot)com> wrote:
>> Several times recently one of our databases has gotten stuck with the
>> following situation:
>>
>> postgres=# select datname, procpid, usename, current_query from
>> pg_stat_activity where current_query != '<IDLE>';
>> datname | procpid | usename |
>> current_query
>> ------------+---------+----------+--------------------------------------------------------------------------------------------------------
>> emolecules | 13503 | customerdb | select tableid from hitlist_table_pool
>> where hitlistid<= 0 for update
>> emolecules | 32082 | customerdb | select tableid from hitlist_table_pool
>> where hitlistid<= 0 for update
>> emolecules | 17974 | customerdb | select tableid from hitlist_table_pool
>> where hitlistid<= 0 for update
>> emolecules | 31299 | customerdb | select tableid from hitlist_table_pool
>> where hitlistid = 0 limit 1 for update
>> emolecules | 30247 | customerdb | select tableid from hitlist_table_pool
>> where hitlistid = 0 limit 1 for update
>> postgres | 1705 | postgres | select datname, procpid, usename,
>> current_query from pg_stat_activity where current_query != '<IDLE>';
>> emolecules | 28866 | customerdb |<IDLE> in transaction
>> emolecules | 21394 | customerdb | select tableid from hitlist_table_pool
>> where hitlistid = 0 limit 1 for update
>> emolecules | 22237 | customerdb | select tableid from hitlist_table_pool
>> where hitlistid = 0 limit 1 for update
>> (9 rows)
>>
>> It's obvious that they're all waiting ... but for what? The "<IDLE>"
>> process looks like the culprit, but how do I figure out what it's doing?
>> The next time this happens, what queries can I run to help diagnose what's
>> going on?
>> This is PG 8.4.4 on Ubuntu 10.
> Does this help?
>
> http://wiki.postgresql.org/wiki/Lock_Monitoring
Yes, thanks! That's exactly what I needed.
Craig
From | Date | Subject | |
---|---|---|---|
Next Message | Kasia Tuszynska | 2011-11-30 19:30:26 | Re: transaction error handling |
Previous Message | Lukasz Brodziak | 2011-11-30 14:56:42 | Re: Database is in recovery mode. |