Commit 9c0e2b91 authored by Heikki Linnakangas's avatar Heikki Linnakangas

Fix walsender handling of postmaster shutdown, to not go into endless loop.

This bug was introduced by my patch to use the regular die/quickdie signal
handlers in walsender processes. I tried to make walsender exit at next
CHECK_FOR_INTERRUPTS() by setting ProcDiePending, but that's not enough, you
need to set InterruptPending too. On second thoght, it was not a very good
way to make walsender exit anyway, so use proc_exit(0) instead.

Also, send a CommandComplete message before exiting; that's what we did
before, and you get a nicer error message in the standby that way.

Reported by Thom Brown.
parent 95d035e6
...@@ -711,8 +711,11 @@ WalSndLoop(void) ...@@ -711,8 +711,11 @@ WalSndLoop(void)
XLogSend(output_message, &caughtup); XLogSend(output_message, &caughtup);
if (caughtup && !pq_is_send_pending()) if (caughtup && !pq_is_send_pending())
{ {
ProcDiePending = true; /* Inform the standby that XLOG streaming is done */
continue; /* don't want to wait more */ pq_puttextmessage('C', "COPY 0");
pq_flush();
proc_exit(0);
} }
} }
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment