Re: [PERFORM] Sort causes system to freeze

2008-12-02 Thread Tom Lane
Craig James [EMAIL PROTECTED] writes:
 Maybe this is an obviously dumb thing to do, but it looked reasonable
 to me.  The problem is, the seemingly simple sort below causes a
 fairly powerful computer to completely freeze for 5-10 minutes.

trace_sort output might be informative.

regards, tom lane

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


Re: [PERFORM] Sort causes system to freeze

2008-12-02 Thread Richard Huxton
Don't reply to another message when starting a new thread. People will
miss your message.

Craig James wrote:
 Maybe this is an obviously dumb thing to do, but it looked reasonable to
 me.

Looks reasonable here too - except I'm not sure what I'd do with 2
million rows of sorted table in my console. I'm guessing you're piping
the output into something.

  The problem is, the seemingly simple sort below causes a fairly
 powerful computer to completely freeze for 5-10 minutes.  During the
 sort, you can't login, you can't use any shell sessions you already have
 open, the Apache server barely works, and even if you do nice -20 top
 before you start the sort, the top(1) command comes to a halt while the
 sort is proceeding!  As nearly as I can tell, the sort operation is
 causing a swap storm of some sort -- nothing else in my many years of
 UNIX/Linux experience can cause a nice -20 process to freeze.

Nothing should cause that to your machine. I've never seen top just
freeze unless you set up some sort of fork-bomb and ramp the load up so
fast it can't cope. Oh, and nice-ing the client isn't going to do
anything to the backend actually doing the sorting.

 The sort operation never finishes -- it's always killed by the system. 
 Once it dies, everything returns to normal.

You're running out of memory then. It'll be the out-of-memory killer
(assuming you're on Linux).

 This is 8.3.0.  (Yes, I'll upgrade soon.)

Make soon more urgent than it has been up to now - no point in risking
all your data to some already fixed bug is there? Unless you've been
carefully tracking the release notes and have established that there's
no need in your precise scenario.

 Is this a known bug, or do I
 have to rewrite this query somehow?  Maybe add indexes to all four
 columns being sorted?

Indexes won't necessarily help if you're sorting the whole table. Maybe
if you had one on all four columns.

 = explain select * from plus order by supplier_id, compound_id, units,
 price;

 max_connections = 1000
 shared_buffers = 2000MB
 work_mem = 256MB

So can you support (1000 * 256 * 2) + 2000 MB of RAM?

 effective_cache_size = 4GB

...while leaving 4GB free for disk caching?

 Machine: Dell, 8x64-bit CPUs, 8GB ram, Perc6i battery-backed RAID
 controller, 8 disks as RAID10

It appears not. Remember that work_mem is not only per-connection, a
single query can use multiples of it (hence the *2 above). If you
genuinely have a lot of connections I'd drop it down to (say) 4MB to
make sure you don't swap on a regular basis (should probably be even
lower to be truly safe).

Then, for the odd case when you need a large value, issue a SET work_mem
before the query.

-- 
  Richard Huxton
  Archonet Ltd

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


[PERFORM] Sort causes system to freeze

2008-12-01 Thread Craig James

Maybe this is an obviously dumb thing to do, but it looked reasonable to me.  The problem is, the 
seemingly simple sort below causes a fairly powerful computer to completely freeze for 5-10 
minutes.  During the sort, you can't login, you can't use any shell sessions you already have open, 
the Apache server barely works, and even if you do nice -20 top before you start the 
sort, the top(1) command comes to a halt while the sort is proceeding!  As nearly as I can tell, 
the sort operation is causing a swap storm of some sort -- nothing else in my many years of 
UNIX/Linux experience can cause a nice -20 process to freeze.

The sort operation never finishes -- it's always killed by the system.  Once it 
dies, everything returns to normal.

This is 8.3.0.  (Yes, I'll upgrade soon.)  Is this a known bug, or do I have to 
rewrite this query somehow?  Maybe add indexes to all four columns being sorted?

Thanks!
Craig


= explain select * from plus order by supplier_id, compound_id, units, price;
 QUERY PLAN   
---

Sort  (cost=5517200.48..5587870.73 rows=28268100 width=65)
  Sort Key: supplier_id, compound_id, units, price
  -  Seq Scan on plus  (cost=0.00..859211.00 rows=28268100 width=65)

= \d plus   Table emol_warehouse_1.plus
   Column | Type  | Modifiers 
---+---+---
supplier_id   | integer   | 
supplier_name | text  | 
compound_id   | text  | 
amount| text  | 
units | text  | 
price | numeric(12,2) | 
currency  | text  | 
description   | text  | 
sku   | text  | 
Indexes:

   i_plus_compound_id btree (supplier_id, compound_id)
   i_plus_supplier_id btree (supplier_id)


max_connections = 1000
shared_buffers = 2000MB
work_mem = 256MB
max_fsm_pages = 100
max_fsm_relations = 5000
synchronous_commit = off
#wal_sync_method = fdatasync
wal_buffers = 256kB
checkpoint_segments = 30
effective_cache_size = 4GB

Machine: Dell, 8x64-bit CPUs, 8GB ram, Perc6i battery-backed RAID controller, 8 
disks as RAID10

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