Re: explanation of some configs

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

 



Thomas Finneid wrote:
Joshua D. Drake wrote:
On Sat, 2009-02-07 at 01:52 +0100, Thomas Finneid wrote:
>>
effective_cache_size
>>
This is just a hint to tell the planner how much cache will generally be
available.

ok, but available for what?
for storing the data/tables/rows in memory so it does not have the disk subsystem.

The number should be reflective of your shared buffers +
available operating system cache. If you database is postgresql only you
can generally set this very high 75% of available ram. If not then you
need to tone it down.

So that means, if I have 8GB ram and have set shared buffer to e.g. 4GB, I should set the effective_cache_size to at least 4GB otherwise the planner will assume I dont have as much memory available so it would be sort of pointless so set shared_buffer to 4GB?
No because other parts of Postgresql use the shared_buffer to store tables/data in memory. If shared_buffer is set low then the system will be during more disk IO as it can't fit that much into memory. Another critical setting to look at is work_mem where all the complex sorting, and joins are done which is not related to shared buffers. So leave room in memory for these processes


checkpoint_segments
    - specifies the number of segments?

The number of segments that will be used before a checkpoint is forced.

So to sum it up:

- Specifies the number of memory segments the WAL will use before a checkpoint occur. (A checkpoint guarantees the data has been written to disk, including dirty pages.)
- A segment is 16MB and the number of actually used segments are dynamic.
- If this number is too low or the transaction is large, PG will spend more time on performing checkpoint operations which decreases performance.

Q1:

So checkpoint_time is then just another way of expressing the same?
I.e. to ensure that if the segments have not been filled, which would foce a checkpoint, a checkpoint is at least forced at the specified time lapse?
Yes and No Checkpoint_time does forces a check point regardless if the segment is full or not. Checkpoint_segment is used to force a check point based on size. In a big databases a checkpoint could get very large before time had elapsed and if server cashed all that work would be rolled back.

Q2:

So how does this relate to WAL buffers? It seems to me that wal_buffers are not needed. Based on the above explanation.
This is number of pages in shared memory the Postgresql uses before WAL is written to disk this is used to improve performance for large writes.



regards

thomas


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

[Postgresql General]     [Postgresql PHP]     [PHP Users]     [PHP Home]     [PHP on Windows]     [Kernel Newbies]     [PHP Classes]     [PHP Books]     [PHP Databases]     [Yosemite]

  Powered by Linux