Re: BUG #15449: file_fdw using program cause exit code error whenusing LIMIT - Mailing list pgsql-bugs

From Etsuro Fujita
Subject Re: BUG #15449: file_fdw using program cause exit code error whenusing LIMIT
Date
Msg-id 5BE966F4.1040702@lab.ntt.co.jp
Whole thread Raw
In response to Re: BUG #15449: file_fdw using program cause exit code error whenusing LIMIT  (Kyotaro HORIGUCHI <horiguchi.kyotaro@lab.ntt.co.jp>)
Responses Re: BUG #15449: file_fdw using program cause exit code error whenusing LIMIT
Re: BUG #15449: file_fdw using program cause exit code error whenusing LIMIT
List pgsql-bugs
(2018/11/12 18:52), Kyotaro HORIGUCHI wrote:
> At Fri, 09 Nov 2018 18:27:09 +0900, Etsuro Fujita<fujita.etsuro@lab.ntt.co.jp>  wrote
in<5BE552ED.4040304@lab.ntt.co.jp>
>>> Ok, I can live with that with no problem.
>>
>> OK
> ...
>>> I think Thomas just saying that reading more lines can develop
>>> problems. According to the current discussion, we should error
>>> out if we had SEGV when limit 1.
>>
>> Ah, I misread that.  Sorry for the noise.
>
> Being said that, the ruby case may suggest that we should be more
> tolerant for the crash-after-limit case.

The Ruby case would be sad, but I'm not sure we can handle such a case 
safely in general, because core and file_fdw don't have enough knowledge 
about whether a non-zero exit code returned from pclose is OK or not, 
which would actually depend on the called program.  One approach for 
that would be to add an option to file_fdw for the called program to 
tell it to ignore those exit codes, which would be somewhat similar to 
what Thomas proposed [1].

>>> In my understanding processes not connected to a
>>> terminal(tty/pts) cannot receive TTIN/TTOU (unless someone sent
>>> it artifically).  Since child processes are detached by setsid()
>>> (on Linux), programs called in that way also won't have a
>>> controlling terminal at the start time and I suppose they have no
>>> means to connect to one since they are no longer on the same
>>> session with postmaster.
>>
>> For TTIN and TTOU, we would first need to make clear the reason for
>> the inconsistency Thomas pointed out.  I'm wondering if we should
>> leave the TTIN/TTOU stuff for future work.
>
> Inconsistency?

By "the inconsistency" I mean his words:

Why do bgwriter.c, startup.c, ... set SIGTTIN and SIGTTOU back to 
SIG_DFL, but not regular backends?

> I read the Thomas's messages as "TTIO/TTOU are not
> needed to our busines and we don't have a reason to restore them
> before calling external programs other than just plaster
> seemingly consistency." And I agree to the analysis and I agree
> to you on the point that it doens't need consideration just now.

OK

> If the consistency means the different behaviors between perl and
> ruby, (as written in another message,) I'm inclined to vote for
> having a bit more tolerance for error of external programs as my
> second patch.

Maybe my explanation was not enough, but I don't mean that.

Thanks!

Best regards,
Etsuro Fujita

[1] 
https://www.postgresql.org/message-id/CAEepm%3D0fBPiRkSiJ3v4ynm%2BaP-A-dhuHjTFBAxwo59EkE2-E5Q%40mail.gmail.com


pgsql-bugs by date:

Previous
From: "Mengcheng.Zhong,Tony"
Date:
Subject: Report a bug about timestamp data type
Next
From: Derek Nelson
Date:
Subject: Re: Tables created WITH OIDS cannot be dumped/restored properly