| From: | "Merlin Moncure" <mmoncure(at)gmail(dot)com> | 
|---|---|
| To: | Justin <justin(at)emproshunts(dot)com> | 
| Cc: | Sabbiolina <sabbiolina(at)gmail(dot)com>, pgsql-hackers(at)postgresql(dot)org | 
| Subject: | Re: [PERFORM] Memory question on win32 systems | 
| Date: | 2008-05-29 19:10:50 | 
| Message-ID: | b42b73150805291210h1f1adf96o42b599d7d5aa105d@mail.gmail.com | 
| Views: | Whole Thread | Raw Message | Download mbox | Resend email | 
| Thread: | |
| Lists: | pgsql-hackers | 
> On Thu, May 29, 2008 at 10:19 AM, Justin <justin(at)emproshunts(dot)com> wrote:
> Quoting You "Also, postgresql doesn't as a rule cache 'results and queries'.
>
> Then what is the purpose of shared buffers if nothing is being reused  is it
> only used to keep track locks, changes and what is to being spooled to the
> kernel???
not much.  PostgreSQL provides an alternative file cache to the o/s
buffer cache (rather, it layers on top of it).  The performance
difference between these caches is an interesting topic.  In my
experience, it isn't very much, so I tend to keep shared buffers on
the low side.
> I'm confussed trying to figure out how caches are being use and being moving
> through postgresql backend.   As many have stated that small database can
> fit completely in the caches How does that really work.
If your database is smaller than working memory, it will be completely
cached all the time, unless you have some big transient memory demand
(a big sort, or result set).  It's just a matter of which cache it
sits in...o/s, or postgres cache, or both.
This is actually the normal state of affairs in many databases.
memory .conf optimization is pretty marginal in effect until your
database is 'big' in terms of relative size to memory, does a lot of
sorting (work_mem becomes important), or receives a lot of writing
(vacuum, sync, checkpoints, and bgwriter become important).  There are
a few things you have to pay attention to, especially in older
versions.  For example effective cache size...but mainly because it
affects query plans chosen, not cache policy.
For smallish databases, your best investment is writing efficient
queries and good index strategy.
merlin
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Merlin Moncure | 2008-05-29 19:16:57 | Re: Core team statement on replication in PostgreSQL | 
| Previous Message | Robert Hodges | 2008-05-29 19:05:18 | Re: Core team statement on replication in PostgreSQL |