Re: slow query, different plans - Mailing list pgsql-performance
| From | Midge Brown | 
|---|---|
| Subject | Re: slow query, different plans | 
| Date | |
| Msg-id | 910386A76D2440E0A58441E48B0F31AC@BERNICE Whole thread Raw | 
| In response to | slow query, different plans ("Midge Brown" <midgems@sbcglobal.net>) | 
| List | pgsql-performance | 
Diff of config files is below. default_statistics_target in both is currently at the default of 100, though I'm going to try increasing that for this table as Tom Lane suggested.  
-Midge
----- Original Message ----- 
From: Greg Williamson
Sent: Friday, August 03, 2012 6:30 PM
Subject: Re: [PERFORM] slow query, different plans
Midge --
Sorry for top-quoting -- challenged mail.
Perhaps a difference in the stats estimates -- default_statistics_target ?
Can you show us a diff between the postgres config files for each instance ? Maybe something there ...
Greg Williamson
From: Midge Brown <midgems@sbcglobal.net>
To: pgsql-performance@postgresql.org
Sent: Friday, August 3, 2012 5:38 PM
Subject: [PERFORM] slow query, different plans
log_autovacuum_min_duration = 10
autovacuum_max_workers = 3
autovacuum_naptime = 1min
autovacuum_vacuum_threshold = 50
autovacuum_analyze_threshold = 50
autovacuum_vacuum_scale_factor = 0.2
autovacuum_analyze_scale_factor = 0.1
autovacuum_freeze_max_age = 200000000
autovacuum_vacuum_cost_delay = 10ms (changed earlier today from 1000ms)
autovacuum_vacuum_cost_limit = -1wal_level = minimalwal_buffers = 16MBThe only recent change was moving the 3 databases we have from multiple raid 1 drives with tablespaces spread all over to one large raid10 with indexes and data in pg_default. WAL for this table was moved as well.Does anyone have any suggestions on where to look for the problem?clientlog table info:Size: 1.94GColumn | Type | Modifiers
----------+-----------------------------+-----------
pid0 | integer | not null
rid | integer | not null
verb | character varying(32) | not null
noun | character varying(32) | not null
detail | text |
path | character varying(256) | not null
ts | timestamp without time zone |
applies2 | integer |
toname | character varying(128) |
byname | character varying(128) |
Indexes:
"clientlog_applies2" btree (applies2)
"clientlog_pid0_key" btree (pid0)
"clientlog_rid_key" btree (rid)
"clientlog_ts" btree (ts)The query, hardware info, and links to both plans:explain analyze select max(ts) as ts from clientlog where applies2=256;Production server:- 4 dual-core AMD Opteron 2212 processors, 2010.485 MHz
- 64GB RAM
- 464GB RAID10 drive
- Linux 2.6.18-164.el5 #1 SMP Thu Sep 3 03:28:30 EDT 2009 x86_64 x86_64 x86_64 GNU/LinuxPostgreSQL 9.0.4 on x86_64-unknown-linux-gnu, compiled by GCC gcc (GCC) 4.1.2 20080704 (Red Hat 4.1.2-46), 64-bithttp://explain.depesz.com/s/8R4
From laptop running Linux 2.6.34.9-69.fc13.868 with 3G ram against a copy of the same table:PostgreSQL 9.0.2 on i686-pc-linux-gnu, compiled by GCC gcc (GCC) 4.4.4 20100630 (Red Hat 4.4.4-10), 32-bithttp://explain.depesz.com/s/NQlThank you,Midge==================Here's the diff of the 2 config files. I didn't list the autovacuum settings since the laptop is a development machine with that feature turned off.109c109
< shared_buffers = 28MB # min 128kB
---
> shared_buffers = 4GB
118,120c118,120
< #work_mem = 1MB # min 64kB
< #maintenance_work_mem = 16MB # min 1MB
< #max_stack_depth = 2MB # min 100kB
---
> work_mem = 16MB
> maintenance_work_mem = 256MB
> max_stack_depth = 2MB
130c130
< #vacuum_cost_delay = 0ms # 0-100 milliseconds
---
> vacuum_cost_delay = 10ms
134c134
< #vacuum_cost_limit = 200 # 1-10000 credits
---
> vacuum_cost_limit = 200 # 1-10000 credits
153c153
< #wal_level = minimal # minimal, archive, or hot_standby
---
> wal_level = minimal # minimal, archive, or hot_standby
165c165
< wal_buffers = 64kB # min 32kB
---
> wal_buffers = 16MB
174c174
< checkpoint_segments = 3 # in logfile segments, min 1, 16MB each
---
> checkpoint_segments = 64 # in logfile segments, min 1, 16MB each
176,177c176,177
< checkpoint_completion_target = 0.5 # checkpoint target duration, 0.0 - 1.0
< checkpoint_warning = 30s # 0 disables
---
> checkpoint_completion_target = 0.7 # checkpoint target duration, 0.0 - 1.0
> checkpoint_warning = 30s # 0 disables
231c231
< #effective_cache_size = 128MB
---
> effective_cache_size = 10GB
413c414
pgsql-performance by date: