From: | "Craig A(dot) James" <cjames(at)modgraph-usa(dot)com> |
---|---|
To: | Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> |
Cc: | pgsql-performance(at)postgresql(dot)org, sgunderson(at)bigfoot(dot)com |
Subject: | Re: Kill a session |
Date: | 2006-07-14 15:17:38 |
Message-ID: | 44B7B592.1090405@modgraph-usa.com |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-performance |
Tom Lane wrote:
> "Craig A. James" <cjames(at)modgraph-usa(dot)com> writes:
>> Bottom line is that I was expecting "instant death" with SIGTERM, but
>> instead got an agonizing, drawn out -- but safe -- death of the query.
>
> What was the query exactly?
>
> Our expectation is that all or at least most queries should respond to
> SIGINT or SIGTERM interrupts pretty rapidly, say on a less-than-a-second
> timescale. However there are various loops in the backend that fail to
> execute CHECK_FOR_INTERRUPTS sufficiently often :-(. We've been
> gradually finding and fixing these, and will be glad to fix your case
> if you provide enough details to pin it down. You might be interested
> in this current thread about a similar problem:
>
> http://archives.postgresql.org/pgsql-patches/2006-07/msg00039.php
Thanks, this is good information. The qsort is a distinct possibility. The query is a big
insert into some_hitlist (select id from another_hitlist join data_table on (...))
where the hitlists are unindexed. So it may be using a merge-join with qsort. When I have a few minutes, I'll turn on logging in the app and find the exact SQL, and run an EXPLAIN ANALYZE and see what's really happening.
It's also possible that the INSERT itself is the problem, or adds to the problem. The SIGINT may come after a few million rows have been inserted, so it would have to clean that up, right?
Thanks,
Craig
From | Date | Subject | |
---|---|---|---|
Next Message | Tom Lane | 2006-07-14 16:25:13 | Re: Kill a session |
Previous Message | Markus Schaber | 2006-07-14 11:28:29 | Re: Kill a session |