summaryrefslogtreecommitdiff
path: root/contrib/test_decoding/sql
diff options
context:
space:
mode:
authorHeikki Linnakangas <heikki.linnakangas@iki.fi>2018-05-05 01:34:53 +0300
committerHeikki Linnakangas <heikki.linnakangas@iki.fi>2018-05-05 01:34:53 +0300
commit0668719801838aa6a8bda330ff9b3d20097ea844 (patch)
tree72e42723ac95e2273fed0bf46c620cccb833b01a /contrib/test_decoding/sql
parentd2599ecfcc74fea9fad1720a70210a740c716730 (diff)
Fix scenario where streaming standby gets stuck at a continuation record.
If a continuation record is split so that its first half has already been removed from the master, and is only present in pg_wal, and there is a recycled WAL segment in the standby server that looks like it would contain the second half, recovery would get stuck. The code in XLogPageRead() incorrectly started streaming at the beginning of the WAL record, even if we had already read the first page. Backpatch to 9.4. In principle, older versions have the same problem, but without replication slots, there was no straightforward mechanism to prevent the master from recycling old WAL that was still needed by standby. Without such a mechanism, I think it's reasonable to assume that there's enough slack in how many old segments are kept around to not run into this, or you have a WAL archive. Reported by Jonathon Nelson. Analysis and patch by Kyotaro HORIGUCHI, with some extra comments by me. Discussion: https://www.postgresql.org/message-id/CACJqAM3xVz0JY1XFDKPP%2BJoJAjoGx%3DGNuOAshEDWCext7BFvCQ%40mail.gmail.com
Diffstat (limited to 'contrib/test_decoding/sql')
0 files changed, 0 insertions, 0 deletions