Re: signal handling in plpython - Mailing list pgsql-hackers

From Andres Freund
Subject Re: signal handling in plpython
Date
Msg-id 20161014175324.32ikxm7g5mryfrtv@alap3.anarazel.de
Whole thread Raw
In response to Re: signal handling in plpython  (Tom Lane <tgl@sss.pgh.pa.us>)
List pgsql-hackers
On 2016-10-14 13:50:35 -0400, Tom Lane wrote:
> Heikki Linnakangas <hlinnaka@iki.fi> writes:
> > On 14 October 2016 16:22:12 EEST, Tom Lane <tgl@sss.pgh.pa.us> wrote:
> >> I don't know whether to laugh or cry, but that code is a joke.  Just
> >> silently fail if you can't get the lock?
> 
> > Heh, ok, let me rephrase: I believe it's *intended* to be callable from a signal handler :). Whether it actually
worksis another question. Perhaps there's some mitigating conditions there, I don't know.
 
> 
> > For our use case, it's actually not too bad if Py_AddPendingCall gives up and does nothing. Then the python
functionwill simply not be interrupted until next SPI call, which is the current situation anyway.
 
> 
> I dunno.  If the failure were very low-probability, you could maybe live
> with that behavior, but I'm not sure it is.  Presumably the Python
> interpreter loop is taking that lock once per statement (at least), so
> that it can tell if there's something to do.  That'd suggest that the
> fraction of time in which the lock is held is not negligible.

Since that's how python's signal handling works, I'm not sure that's
really our problem.

Greetings,

Andres Freund



pgsql-hackers by date:

Previous
From: Tom Lane
Date:
Subject: Re: signal handling in plpython
Next
From: Robert Haas
Date:
Subject: Re: signal handling in plpython