Re: updated qCache

From: Neil Conway <nconway(at)klamath(dot)dyndns(dot)org>
To: "Dann Corbit" <DCorbit(at)connx(dot)com>
Cc: pgsql-hackers(at)postgresql(dot)org
Subject: Re: updated qCache
Date: 2002-04-17 22:05:59
Message-ID: 20020417180559.451841b4.nconway@klamath.dyndns.org
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

On Wed, 17 Apr 2002 14:34:45 -0700
"Dann Corbit" <DCorbit(at)connx(dot)com> wrote:
> However, I've tentatively decided that I think the best
> way to go forward is to rewrite this code. IMHO the utility of
> plans cached in shared memory is fairly limited, but the
> code that implements this adds a lot of complex to the patch.
> >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
> DC% Why do you imagine that the utility is limited?

(1) It's difficult to tell whether a given plan has already been
prepared: the server could have been restarted in the mean-time,
for example. We could allow app developers to check if a
given has already been prepared, but that's inconvenient,
and the benefits seem fairly small.

(2) Shared memory is a bad storage location for variable-sized
data, like query plans. What happens if you're asked to
cache a plan larger than the free space in the shared cache?
You could perhaps free up some space by removing another
entry, but that means that every invocation of EXECUTE
needs to be prepared for the target plan to have been
evicted from the cache -- which is irritating.

(3) Managing concurrent access to the shared cache may (or may
not) be a performance issue.

I'm not saying it's a bad idea, I just think I'd like to
concentrate on the locally-cached plans for now and see if
there is a need to add shared plans later.

> <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
>
> I'm planning to re-implement PREPARE/EXECUTE with support only
> for locally-prepared plans, using the existing patch as a
> guide. The result should be a simpler patch -- once it's
> in CVS we can worry about more advanced plan caching
> techiques. Any complaints/comments on this plan?
> >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
> DC% Why not allow both kinds and make it configurable...
> DC% local/shared/both.

That's what the current patch does.

Cheers,

Neil

--
Neil Conway <neilconway(at)rogers(dot)com>
PGP Key ID: DB3C29FC

In response to

Responses

Browse pgsql-hackers by date

  From Date Subject
Next Message Bill Cunningham 2002-04-17 22:20:08 Re: Index Scans become Seq Scans after VACUUM ANALYSE
Previous Message Bruce Momjian 2002-04-17 22:05:54 Re: Index Scans become Seq Scans after VACUUM ANALYSE