From: | Tom Lane <tgl(at)sss(dot)pgh(dot)pa(dot)us> |
---|---|
To: | Noah Misch <noah(at)leadboat(dot)com> |
Cc: | Francesco Degrassi <francesco(dot)degrassi(at)optionfactory(dot)net>, pgsql-bugs(at)lists(dot)postgresql(dot)org |
Subject: | Re: Leader backend hang on IPC/ParallelFinish when LWLock held at parallel query start |
Date: | 2024-09-18 05:18:48 |
Message-ID: | 1744648.1726636728@sss.pgh.pa.us |
Views: | Raw Message | Whole Thread | Download mbox | Resend email |
Thread: | |
Lists: | pgsql-bugs |
Noah Misch <noah(at)leadboat(dot)com> writes:
> On Wed, Sep 18, 2024 at 12:23:42AM -0400, Tom Lane wrote:
>> I actually think that the problem is somewhere upstream of here:
>> what in the world are we doing invoking planning and execution of
>> arbitrary queries in a context where interrupts are held off?
> It would be nice to never run planning or execution with interrupts held. The
> concrete examples so far involve btree operator classes with non-C support
> functions. How practical would it be to release buffer content locks before
> running index support functions?
Ugh. Probably not very. We have to be able to perform comparison
operations within the scanning of a page. Even if it could be made
to work correctly to release and re-acquire the buffer lock many
times per page, it sounds awful for performance.
> An alternative would be blocking non-C
> support functions (and instructing C support function authors to not use
> planner/executor). Non-C support functions have been handy for testing if
> nothing else, though. Do non-bundled modules rely on non-C support functions?
Dunno ... but the OP claimed this is a case that's seen in the
field, so maybe somebody is doing it. On the whole I don't see
how a btree support function can be considered not to be a low-level
thing, so maybe restricting what it can do is the best answer.
I fear though that the restriction can't simply be to forbid
parallel sub-queries.
On the third hand: you can't implement a btree comparison function
in SQL and simultaneously claim with a straight face that you
expect premium performance. Could we set things up so that
buffer release/reacquires happen only with non-C support functions?
This still requires that such behavior is safe in the face of
concurrent index activity, which I'm not sure is practical.
(Also, I'm not sure to what extent we'd still be testing what
we wish to with test comparison functions written in SQL.)
regards, tom lane
From | Date | Subject | |
---|---|---|---|
Next Message | Noah Misch | 2024-09-18 05:30:26 | Re: Leader backend hang on IPC/ParallelFinish when LWLock held at parallel query start |
Previous Message | Noah Misch | 2024-09-18 05:04:34 | Re: Leader backend hang on IPC/ParallelFinish when LWLock held at parallel query start |