Re: High CPU Load - Mailing list pgsql-performance

From Jérôme BENOIS
Subject Re: High CPU Load
Date
Msg-id 1158244032.5226.49.camel@localhost.localdomain
Whole thread Raw
In response to Re: High CPU Load  (Scott Marlowe <smarlowe@g2switchworks.com>)
Responses Re: High CPU Load
List pgsql-performance
Hello,




Le jeudi 14 septembre 2006 à 09:21 -0500, Scott Marlowe a écrit :
> On Thu, 2006-09-14 at 09:17, Jérôme BENOIS wrote:
> > Hi Tom,
> >
> > Le jeudi 14 septembre 2006 à 10:13 -0400, Tom Lane a écrit :
> > > =?ISO-8859-1?Q?J=E9r=F4me?= BENOIS <benois@argia-engineering.fr> writes:
> > > >    I migrated Postgres server from 7.4.6 to 8.1.4, But my server is
> > > > completely full, by moment load average > 40
> > >
> > > Did you remember to ANALYZE the whole database after reloading it?
> > > pg_dump/reload won't by itself regenerate statistics.
> > >
> > >             regards, tom lane
> > I tested, dump + restore + vaccumdb --analyze on all databases but no change ...
>
>
> OK, set your db to log queries that take more than a few seconds to
> run.  Execute those queries by hand with an explain analyze in front and
> post the output here.
>
> ---------------------------(end of broadcast)---------------------------
> TIP 6: explain analyze is your friend

i tested all queries, but she used indexes ... an example :

 explain analyze select distinct
INTEGER_VALUE,DATE_VALUE,EI_ID,VALUE_TYPE,FLOAT_VALUE,ID,TEXT_VALUE,CATEGORY_ID,STRING_VALUE,CATEGORYATTR_ID,NAME from
(((select distinct ei_id as EIID from mpng2_ei_attribute as reqin1 where reqin1.CATEGORYATTR_ID = 0 AND
reqin1.TEXT_VALUEilike '' and ei_id in ( select distinct ei_id as EIID from mpng2_ei_attribute as reqin2 where
reqin2.CATEGORYATTR_ID= 0 AND reqin2.TEXT_VALUE ilike '' and ei_id in ( select distinct ei_id as EIID from
mpng2_ei_attributeas reqin3 where reqin3.NAME = '' AND reqin3.STRING_VALUE = '' ) ) ) ) ) as req0 join
mpng2_ei_attributeon req0.eiid = mpng2_ei_attribute.ei_id order by ei_id asc; 
          QUERY PLAN

----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
 Unique  (cost=758.53..762.19 rows=122 width=233) (actual
time=0.191..0.191 rows=0 loops=1)
   ->  Sort  (cost=758.53..758.84 rows=122 width=233) (actual
time=0.182..0.182 rows=0 loops=1)
         Sort Key: mpng2_ei_attribute.ei_id,
mpng2_ei_attribute.integer_value, mpng2_ei_attribute.date_value,
mpng2_ei_attribute.value_type, mpng2_ei_attribute.float_value,
mpng2_ei_attribute.id, mpng2_ei_attribute.text_value,
mpng2_ei_attribute.category_id, mpng2_ei_attribute.string_value,
mpng2_ei_attribute.categoryattr_id, mpng2_ei_attribute.name
         ->  Nested Loop  (cost=365.83..754.31 rows=122 width=233)
(actual time=0.126..0.126 rows=0 loops=1)
               ->  Unique  (cost=365.83..374.34 rows=1 width=4) (actual
time=0.116..0.116 rows=0 loops=1)
                     ->  Nested Loop  (cost=365.83..374.34 rows=1
width=4) (actual time=0.108..0.108 rows=0 loops=1)
                           ->  Unique  (cost=350.22..354.69 rows=1
width=4) (actual time=0.097..0.097 rows=0 loops=1)
                                 ->  Nested Loop  (cost=350.22..354.69
rows=1 width=4) (actual time=0.089..0.089 rows=0 loops=1)
                                       ->  Unique  (cost=334.60..335.03
rows=1 width=4) (actual time=0.080..0.080 rows=0 loops=1)
                                             ->  Sort
(cost=334.60..334.82 rows=86 width=4) (actual time=0.072..0.072 rows=0
loops=1)
                                                   Sort Key:
reqin3.ei_id
                                                   ->  Bitmap Heap Scan
on mpng2_ei_attribute reqin3  (cost=2.52..331.84 rows=86 width=4)
(actual time=0.056..0.056 rows=0 loops=1)
                                                         Recheck Cond:
(((name)::text = ''::text) AND ((string_value)::text = ''::text))
                                                         ->  Bitmap
Index Scan on mpng2_ei_attribute_name_svalue  (cost=0.00..2.52 rows=86
width=0) (actual time=0.043..0.043 rows=0 loops=1)
                                                               Index
Cond: (((name)::text = ''::text) AND ((string_value)::text = ''::text))
                                       ->  Bitmap Heap Scan on
mpng2_ei_attribute reqin2  (cost=15.61..19.63 rows=1 width=4) (never
executed)
                                             Recheck Cond:
((reqin2.ei_id = "outer".ei_id) AND (reqin2.categoryattr_id = 0))
                                             Filter: (text_value ~~*
''::text)
                                             ->  BitmapAnd
(cost=15.61..15.61 rows=1 width=0) (never executed)
                                                   ->  Bitmap Index Scan
on mpng2_ei_attribute_ei_id  (cost=0.00..2.43 rows=122 width=0) (never
executed)
                                                         Index Cond:
(reqin2.ei_id = "outer".ei_id)
                                                   ->  Bitmap Index Scan
on mpng2_ei_attribute_categoryattr  (cost=0.00..12.94 rows=1982 width=0)
(never executed)
Index Cond: (categoryattr_id = 0)
                           ->  Bitmap Heap Scan on mpng2_ei_attribute
reqin1  (cost=15.61..19.63 rows=1 width=4) (never executed)
                                 Recheck Cond: ((reqin1.ei_id =
"outer".ei_id) AND (reqin1.categoryattr_id = 0))
                                 Filter: (text_value ~~* ''::text)
                                 ->  BitmapAnd  (cost=15.61..15.61
rows=1 width=0) (never executed)
                                       ->  Bitmap Index Scan on
mpng2_ei_attribute_ei_id  (cost=0.00..2.43 rows=122 width=0) (never
executed)
                                             Index Cond: (reqin1.ei_id =
"outer".ei_id)
                                       ->  Bitmap Index Scan on
mpng2_ei_attribute_categoryattr  (cost=0.00..12.94 rows=1982 width=0)
(never executed)
                                             Index Cond:
(categoryattr_id = 0)
               ->  Index Scan using mpng2_ei_attribute_ei_id on
mpng2_ei_attribute  (cost=0.00..378.43 rows=122 width=233) (never
executed)
                     Index Cond: ("outer".ei_id =
mpng2_ei_attribute.ei_id)

Thanks,

--
Jérôme,

python -c "print '@'.join(['.'.join([w[::-1] for w in p.split('.')]) for
p in 'sioneb@gnireenigne-aigra.rf'.split('@')])"

Attachment

pgsql-performance by date:

Previous
From: "Guillaume Smet"
Date:
Subject: Re: High CPU Load
Next
From: "Dave Dutcher"
Date:
Subject: Re: High CPU Load