On Mon, Dec 12, 2011 at 8:33 AM, Craig Ringer <ring...@ringerc.id.au> wrote:

> On 12/12/2011 08:42 AM, Stefan Keller wrote:
>
>> I'd like to clear the PostgreSQL cache (e.g. for benchmarking purposes).
>> And I'd like to preload all tuples of a table (say mytable_one) into the
>> cache.
>>
>> AFAIK there is no way to force all caches to be cleared in PostgreSQL
>> with an SQL command.
>> The only way to achieve this, seems to restart PG (server), which is
>> neither an option for benchmarking purposes nor for production.
>>
> You haven't specified your OS, Pg version, etc. This is important.
>
> Pg relies on the OS's disk cache, which it has no way to clear or control.
>
> On Linux, check out the "drop_caches"
>
>
>  But:
>> 1. Isn't it possible to achieve a kind-of cache clearing (in a
>> reliable way) by simply doing a "select * from mytable_two" given
>> mytable_two is at least as large as mytable_one (which is the one we
>> want  to benchmark)?
>>
> No.
>
> If mytable_two is significantly larger than the system memory then maybe,
> and only maybe, you'll clear the cache. Nothing stops Pg from setting
> posix_fadvise(..., ..., ..., POSIX_FADV_SEQUENTIAL|POSIX_**FADV_NOREUSE)
> to help the OS more efficently do the seqscan, though. Even if Pg doesn't
> do that, nothing stops the OS from figuring out Pg's intent and limiting
> how much it caches.
>
>
>
>> 2. I assume that "select * from mytable_one" loads as much of the
>> tuples as it can into the cache. Are there better ways for preloading
>> the contents of a table?
>>
>>
> Nope, again because Pg largely relies on the OS cache.
>
> The OS will *probably* cache the contents of mytable_one when you do a
> seqscan on it, but it might not, and it might be correct in not doing so.
>
> --
> Craig Ringer
>
>
> --
> Sent via pgsql-general mailing list (pgsql-general@postgresql.org)
> To make changes to your subscription:
> http://www.postgresql.org/**mailpref/pgsql-general<http://www.postgresql.org/mailpref/pgsql-general>
>


For caching you can use pgmemcache a contrib module, however you need to
change few thing in your application bcoz its not  application transparent.
 For application transparency you can use infinite-cache.

I believe pgmemcache will do cache clearing, not sure whether its own cache
or OS cache.

Very informative discussion on Caching in PostgreSQL archives.
http://archives.postgresql.org/pgsql-performance/2011-07/msg00001.php

---
Regards,
Raghavendra
EnterpriseDB Corporation
Blog: http://raghavt.blogspot.com/

Reply via email to