]> granicus.if.org Git - postgresql/commit
Reduce delay for last logicalrep feedback message when master goes idle.
authorTom Lane <tgl@sss.pgh.pa.us>
Sat, 1 Jul 2017 16:15:51 +0000 (12:15 -0400)
committerTom Lane <tgl@sss.pgh.pa.us>
Sat, 1 Jul 2017 16:15:51 +0000 (12:15 -0400)
commitf32678c0163d7d966560bdaf41bfbc2cf179a260
treebf3f27c53c33721d2bc3e2533fa6acafe5a85ad9
parent799f8bc76a92d48b0f7988f4cc50da438cacec7c
Reduce delay for last logicalrep feedback message when master goes idle.

The regression tests contain numerous cases where we do some activity on a
master server and then wait till the slave has ack'd flushing its copy of
that transaction.  Because WAL flush on the slave is asynchronous to the
logicalrep worker process, the worker cannot send such a feedback message
during the LogicalRepApplyLoop iteration where it processes the last data
from the master.  In the previous coding, the feedback message would come
out only when the loop's WaitLatchOrSocket call returned WL_TIMEOUT.  That
requires one full second of delay (NAPTIME_PER_CYCLE); and to add insult
to injury, it could take more than that if the WaitLatchOrSocket was
interrupted a few times by latch-setting events.

In reality we can expect the slave's walwriter process to have flushed the
WAL data after, more or less, WalWriterDelay (typically 200ms).  Hence,
if there are unacked transactions pending, make the wait delay only that
long rather than the full NAPTIME_PER_CYCLE.  Also, move one of the
send_feedback() calls into the loop main line, so that we'll check for the
need to send feedback even if we were woken by a latch event and not either
socket data or timeout.

It's not clear how much this matters for production purposes, but
it's definitely helpful for testing.

Discussion: https://postgr.es/m/30864.1498861103@sss.pgh.pa.us
src/backend/replication/logical/worker.c