Re: [GENERAL] RAM, the more the merrier?

Поиск
Список
Период
Сортировка
От Joshua D. Drake
Тема Re: [GENERAL] RAM, the more the merrier?
Дата
Msg-id cf23869b-f0a2-eca6-d97f-558ff7bce05f@commandprompt.com
обсуждение исходный текст
Ответ на [GENERAL] RAM, the more the merrier?  (Willy-Bas Loos <willybas@gmail.com>)
Список pgsql-general
On 06/29/2017 07:19 AM, Willy-Bas Loos wrote:
> Hi,
>
> We have a postgresql database that is now 1.4TB in disksize and slowly
> growing.
> In the past, we've had (read) performance trouble with this database and
> the solution was to buy a server that can fit the db into memory. It had
> 0.5 TB of RAM and at the time it could hold all of the data easily.
> Those servers are now old and the db has outgrown the RAM and we are
> doing more reads and writes too (but the problem has not yet returned).

That's o.k., although it is awesome if the database can fit in memory it
is not required by any means. What you really want to aim for is the
active data set being in ram and/or file cache. Though with SSDs even
that isn't nearly as important anymore.

>
> So i am looking into buying new servers. I'm thinking of equipping it
> with 1TB of RAM and room to expand. So the database will not fit
> completely, but largely anyway. Also, if we can afford it, it will have
> SSDs instead of RAID10 SAS spindles.

An average single SSD equates to 8 spinning disks in terms of raw
performance and that isn't quite accurate either because SSDs are better
at general multi tasking.

>
> But I've read that there is some kind of maximum to the shared_buffers,
> where increasing it would actually decrease performance.
> Is 1TB of RAM, or even 2TB always a good thing?

This can be true but it is about proper tuning. If you are on a
reasonably new version of Postgres (9.3+) then shared buffers can
sometimes be as high as 40-50% (I have seen 90% without issue).

> And is there anything special that I should look out for when
> configuring such a server?

You are going to have to tune huge pages and your checkpoints/background
writer.


> Or would it be much better to buy 2 smaller servers and tie them
> together somehow? (partitioning, replication, ...)

That is a big "if". Frankly the size of server you already have with
upgraded hardware (SSDs, cores) may work just fine but it depends. You
can also do something such as have a master->slave(hot standby) and read
load balance between them.

Hope this was helpful and thanks,

JD


--
Command Prompt, Inc. || http://the.postgres.company/ || @cmdpromptinc

PostgreSQL Centered full stack support, consulting and development.
Advocate: @amplifypostgres || Learn: https://pgconf.us
*****     Unless otherwise stated, opinions are my own.   *****


В списке pgsql-general по дате отправления:

Предыдущее
От: Andreas Kretschmer
Дата:
Сообщение: Re: [GENERAL] RAM, the more the merrier?
Следующее
От: Mikhail
Дата:
Сообщение: [GENERAL] [GENERAL] Significant discrepancy in index cost estimation