From: | Neil Conway <neilc(at)samurai(dot)com> |
---|---|
To: | Martin Nickel <martin(at)portant(dot)com> |
Cc: | pgsql-performance(at)postgresql(dot)org |
Subject: | Re: What gets cached? |
Date: | 2005-10-21 21:44:47 |
Message-ID: | 1129931087.19971.12.camel@localhost.localdomain |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-performance |
On Fri, 2005-21-10 at 07:34 -0500, Martin Nickel wrote:
> Let's say I do the same thing in Postgres. I'm likely to have my very
> fastest performance for the first few queries until memory gets filled up.
No, you're not: if a query doesn't hit the cache (both the OS cache and
the Postgres userspace cache), it will run slower. If the caches are
empty when Postgres starts up (which is true for the userspace cache and
might be true of the OS cache), the first queries that are run should be
slower, not faster.
> The only time Postgres seems to take advantage of cached data is when I
> repeat the same (or substantially the same) query.
Caching is done on a page-by-page basis -- the source text of the query
itself is not relevant. If two different queries happen to hit a similar
set of pages, they will probably both benefit from the same set of
cached pages.
> I don't know of any way to view what is actually cached at any point
> in time, but it seems like "most recently used" rather than "most
> frequently used".
The cache replacement policy in 7.4 and older releases is simple LRU.
The policy in 8.0 is ARC (essentially a version of LRU modified to try
to retain hot pages more accurately). The policy in 8.1 is a clock-based
algorithm.
-Neil
From | Date | Subject | |
---|---|---|---|
Next Message | Karl O. Pinc | 2005-10-22 05:05:21 | Using LIMIT 1 in plpgsql PERFORM statements |
Previous Message | Rodrigo Madera | 2005-10-21 17:15:58 | Re: Inefficient escape codes. |