Re: Big difference in time returned by EXPLAIN ANALYZE SELECT ... AND SELECT ...

Поиск
Список
Период
Сортировка
От Craig Ringer
Тема Re: Big difference in time returned by EXPLAIN ANALYZE SELECT ... AND SELECT ...
Дата
Msg-id 4C4D5220.9010101@postnewspapers.com.au
обсуждение исходный текст
Ответ на Big difference in time returned by EXPLAIN ANALYZE SELECT ... AND SELECT ...  (Piotr Gasidło <quaker@barbara.eu.org>)
Ответы Re: Big difference in time returned by EXPLAIN ANALYZE SELECT ... AND SELECT ...
Список pgsql-performance
On 26/07/10 16:35, Piotr Gasidło wrote:
> Hello,
>
> I've found strange problem in my database (8.4.4, but also 9.0beta3,
> default postgresql.conf, shared_buffers raised to 256MB).
>
> EXPLAIN ANALYZE SELECT ...
> Total runtime: 4.782 ms
> Time: 25,970 ms
>
> SELECT ...
> ...
> (21 rows)
>
> Time: 23,042 ms
>
> Test done in psql connected by socket to server (same host, using
> \timing to get runtime).
>
> Does big difference in "Total runtime" and "Time" is normal?

Given that EXPLAIN ANALYZE doesn't transfer large rowsets to the client,
it can't really be time taken to transfer the data, which is the usual
difference between 'explain analyze' timings and psql client-side timings.

Given that, I'm wondering if the difference in this case is planning
time. I can't really imagine the query planner taking 20 seconds (!!) to
run, though, no matter how horrifyingly complicated the query and table
structure were, unless there was something going wrong.

Another possibility, then, is that for some reason queries are being
delayed from starting or delayed before results are being returned, so
the server completes them in a short amount of time but it takes a while
for psql to find out they're finished.

In your position, at this point I'd be doing things like hooking a
debugger up to the postgres backend and interrupting its execution
periodically to see what it's up to while this query runs. I'd also be
using wireshark to look at network activity to see if there were any
clues there. I'd be using "top", "vmstat" and "iostat" to examine
system-level load if it was practical to leave the system otherwise
idle, so I could see if CPU/memory/disk were in demand, and for how long.

--
Craig Ringer

В списке pgsql-performance по дате отправления:

Предыдущее
От: Vlad Arkhipov
Дата:
Сообщение: Explains of queries to partitioned tables
Следующее
От: Yeb Havinga
Дата:
Сообщение: Re: Testing Sandforce SSD