]> git.ipfire.org Git - thirdparty/postgresql.git/commit
Refrain from duplicating data in reorderbuffers
authorAlvaro Herrera <alvherre@alvh.no-ip.org>
Tue, 6 Mar 2018 18:57:20 +0000 (15:57 -0300)
committerAlvaro Herrera <alvherre@alvh.no-ip.org>
Tue, 6 Mar 2018 19:20:03 +0000 (16:20 -0300)
commitd4429d50a21adcc0543701350d5112e3868a3596
treea7c8b4bec39be2e5a47f708838c40b9eb7b6545e
parentcb5c141edac595b74ab611e86f7b1cc2be12c15e
Refrain from duplicating data in reorderbuffers

If a walsender exits leaving data in reorderbuffers, the next walsender
that tries to decode the same transaction would append its decoded data
in the same spill files without truncating it first, which effectively
duplicate the data.  Avoid that by removing any leftover reorderbuffer
spill files when a walsender starts.

Backpatch to 9.4; this bug has been there from the very beginning of
logical decoding.

Author: Craig Ringer, revised by me
Reviewed by: Álvaro Herrera, Petr Jelínek, Masahiko Sawada
src/backend/replication/logical/reorderbuffer.c