Re: NOTIFY does not work as expected
| От | Andres Freund |
|---|---|
| Тема | Re: NOTIFY does not work as expected |
| Дата | |
| Msg-id | 20180703190918.vjqwhqfxx7mrumdq@alap3.anarazel.de обсуждение исходный текст |
| Ответ на | Re: NOTIFY does not work as expected (Tom Lane <tgl@sss.pgh.pa.us>) |
| Список | pgsql-bugs |
On 2018-07-03 14:27:04 -0400, Tom Lane wrote:
> Jeff Janes <jeff.janes@gmail.com> writes:
> > Further diagnosis here is that in the "working" case the client receives a
> > single packet from the server containing both the pg_sleep response, and
> > async response, in that order, and the client processes both of them. In
> > the "broken" case, the client receives a single packet from the server
> > containing the pg_sleep response, and processes it, and then blocks on user
> > input. The async response is immediately available in the next packet if
> > the client would ask for it, but the client doesn't do so.
>
> This suggests that 4f85fde8e introduced an extra output-flush operation
> into the code path, ie it must be flushing the output buffer to the client
> after ReadyForQuery and then again after emitting the Notify.
Hm. There's indeed a
/*
* Must flush the notify messages to ensure frontend gets them promptly.
*/
pq_flush();
in ProcessIncomingNotify(). But that was there before, too. And I don't
see any argument why it'd be a good idea to remove it?
> > If I am diagnosing the right problem, this still doesn't seem like a bug to
> > me.
>
> Well, it seems undesirable to me, both because it implies network traffic
> inefficiency and because clients don't seem to be expecting it.
A report after ~3 years doesn't strike me as a huge argument for that,
and it doesn't seem crazy to believe it'd hurt some users changing
that. And when would you avoid flushing?
> We have another recent complaint that seems to be possibly the
> same thing, bug #15255.
That seems more related to the logical replication apply code than
anything?
Greetings,
Andres Freund
В списке pgsql-bugs по дате отправления: