Search Postgresql Archives

Re: Question about hosting and server grade

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Wed, Mar 25, 2009 at 11:42 AM, Phoenix Kiula <phoenix.kiula@xxxxxxxxx> wrote:
> Hi. I have a questionf or people who run high traffic websites.
>
> We are considering a new dedicated server host for a set of 25
> domains, about 5 of which are very high traffic (80 million clicks a
> day each). A lot of this is VIEW content, but there may be a million
> or so INSERTs and UPDATEs.

Given an 8 hour day, and all million happening then, that's

1000000 / 8*60*60

or 34 transactions per second.  That's not too bad.

> I am told that the biggest speed boost and performance comes from
> memory and fast hard disk. So I'm looking for at least a 16GB RAM and
> SCSI 10k 300GB hard disks.
>
> We will use CentOS 5 with Apache 2. I am also told that PHP etc is
> okay, but Postgresql (the database) is the one that hogs resources
> after a while. So for the database server I need a high end server.

It's not that so much that it's hard to distribute database load
across > 1 server.  I can build a farm with 10 PHP servers and a load
balancer easy enough.  Building a 10 db farm that replicate between
each other is much more work, and may or may not scale particularly
well.  So, with a DB, you are putting more eggs in fewer baskets.

> My question: What's the high end recommendation? Is the following
> config of 4 x quadcore Dunnington Intels with 4 disks on RAID 10 be
> good enough for the above sites? Can I run a database on this config
> of servers for my kind of traffic, or do I need a separate one for PG?
> I suppose the traffic will grow large quite quickly so the 300GB may
> be low, but that we can add as we go along.

I'd spend more money on your disks and RAID controllers, and less on
CPUs.  If you have all those cores and 16 or 32 Gig of ram, and your
RAID controller / 4 disk RAID-10 is your choke point, you can't just
upgrade overnight.

Spend your money on more RAM, (32G isn't much more than 16G and I've
seen it make a world of difference on our servers).  Spend it on
disks.  Number of disks is often more important than RPM etc.  Spend
it on fast RAID controllers with battery backed cache.  Then, consider
upgrading your CPUs.  We have 8 opteron cores in our servers, and 12
Disk RAID-10s under a very fast RAID controller, and we are still I/O
not CPU bound.

Move pg_xlog to its own RAID-1 set.

As a minimum buy a server with enough expansion slots that you can add
the disks later.  The cost difference between a 4 drive 1U case and a
16 drive 3U case is not all that much, and it gives you the option of
adding some drives as you go along.

But all of this depends on the type of workload your db has to do.  If
you're running memory hungry select queries, focus on more memory.  If
you're running lots and lots of little queries with a mix of update,
insert, delete and select, focus on the drives / controller.  If
you're running queries that require a lot of CPU, then focus more on
that.

I haven't seen a lot of workloads that tend to be cpu heavy enough to
need 16 cores and only 4 drives.  I have seen a lot that required 2
cores and 40+ drives to run fast.

So the real answer is to test your workload on something close to what
you're looking at using for a db server and look for bottlenecks.  I'm
betting I/O will be the biggest one once you've got enough memory.

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

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [Postgresql Jobs]     [Postgresql Admin]     [Postgresql Performance]     [Linux Clusters]     [PHP Home]     [PHP on Windows]     [Kernel Newbies]     [PHP Classes]     [PHP Books]     [PHP Databases]     [Postgresql & PHP]     [Yosemite]
  Powered by Linux