Re: Deadlock on "select ... for update"?

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 11/29/11 10:36 AM, Scott Marlowe wrote:
On Tue, Nov 29, 2011 at 11:15 AM, Craig James
<craig_james@xxxxxxxxxxxxxx>  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


--
Sent via pgsql-admin mailing list (pgsql-admin@xxxxxxxxxxxxxx)
To make changes to your subscription:
http://www.postgresql.org/mailpref/pgsql-admin


[Index of Archives]     [KVM ARM]     [KVM ia64]     [KVM ppc]     [Virtualization Tools]     [Spice Development]     [Libvirt]     [Libvirt Users]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite Questions]     [Linux Kernel]     [Linux SCSI]     [XFree86]

  Powered by Linux