Re: performance config help

From: Ivan Voras <ivoras(at)freebsd(dot)org>
To: pgsql-performance(at)postgresql(dot)org
Subject: Re: performance config help
Date: 2010-01-11 17:12:59
Message-ID: hifm6q$dp8$1@ger.gmane.org
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-performance

Bob Dusek wrote:
> On Mon, Jan 11, 2010 at 8:50 AM, Scott Marlowe <scott(dot)marlowe(at)gmail(dot)com
> <mailto:scott(dot)marlowe(at)gmail(dot)com>> wrote:
>
> On Mon, Jan 11, 2010 at 6:44 AM, Bob Dusek <redusek(at)gmail(dot)com
> <mailto:redusek(at)gmail(dot)com>> wrote:
> > Hello,
> >
> > We're running Postgres 8.4.2 on Red Hat 5, on pretty hefty
> hardware...
> >
> > 4X E7420 Xeon, Four cores (for a total of 16 cores)
> > 2.13 GHz, 8M Cache, 1066 Mhz FSB
> > 32 Gigs of RAM
> > 15 K RPM drives in striped raid
>
> What method of striped RAID? RAID-5? RAID-10? RAID-4? RAID-0?
>
>
> RAID-0

And how many drives?

>
> > Things run fine, but when we get a lot of concurrent queries
> running, we see
> > a pretty good slow down.
>
> Definte "a lot".
>
>
> We have an application server that is processing requests. Each request
> consists of a combination of selects, inserts, and deletes. We actually
> see degredation when we get more than 40 concurrent requests. The exact
> number of queries executed by each request isn't known. It varies per
> request. But, an example request would be about 16 inserts and 113
> selects. Any given request can't execute more than a single query at a
> time.

So, you are concurrently trying to achieve more than around 640 writes
and 4520 reads (worst case figures...). This should be interesting. For
40 concurrent requests you will probably need at least 4 drives in
RAID-0 to sustain the write rates (and I'll guess 5-6 to be sure to
cover read requests also, together with plenty of RAM).

> avg-cpu: %user %nice %system %iowait %steal %idle
> 34.29 0.00 7.09 0.03 0.00 58.58
>
> Device: rrqm/s wrqm/s r/s w/s rsec/s wsec/s avgrq-sz
> avgqu-sz await svctm %util
> sda 0.00 112.20 0.00 133.40 0.00 1964.80
> 14.73 0.42 3.17 0.04 0.48
>
> The iowait seems pretty low, doesn't it?

Yes, but you are issuing 133 write operations per seconds per drive(s) -
this is nearly the limit of what you can get with 15k RPM drives
(actually, the limit should be somewhere around 200..250 IOPS but 133
isn't that far).

> top - 10:11:43 up 12 days, 20:48, 6 users, load average: 10.48, 4.16, 2.83
> Tasks: 798 total, 8 running, 790 sleeping, 0 stopped, 0 zombie
> Cpu0 : 33.3%us, 7.6%sy, 0.0%ni, 59.1%id, 0.0%wa, 0.0%hi, 0.0%si,
> 0.0%st

There is one other possibility - since the CPUs are not very loaded, are
you sure the client application with which you are testing is fast
enough to issue enough request to saturate the database?

In response to

Responses

Browse pgsql-performance by date

  From Date Subject
Next Message Kevin Grittner 2010-01-11 17:17:53 Re: performance config help
Previous Message Bob Dusek 2010-01-11 17:10:52 Re: performance config help