Avoid hot standby cancels from VAC FREEZE
authorSimon Riggs
Fri, 26 Jun 2015 23:46:58 +0000 (00:46 +0100)
committerSimon Riggs
Fri, 26 Jun 2015 23:46:58 +0000 (00:46 +0100)
VACUUM FREEZE generated false cancelations of standby queries on an
otherwise idle master. Caused by an off-by-one error on cutoff_xid
which goes back to original commit.

Backpatch to all versions 9.0+

Analysis and report by Marco Nenciarini

Bug fix by Simon Riggs

src/backend/access/heap/heapam.c

index 9918c226c2883f85ffaa9bddf35c621625b3afae..b068483c58ea80dd6afe99f830ebbbd2b805da58 100644 (file)
@@ -7064,7 +7064,13 @@ heap_xlog_freeze_page(XLogRecPtr lsn, XLogRecord *record)
     * consider the frozen xids as running.
     */
    if (InHotStandby)
-       ResolveRecoveryConflictWithSnapshot(cutoff_xid, xlrec->node);
+   {
+       TransactionId latestRemovedXid = cutoff_xid;
+
+       TransactionIdRetreat(latestRemovedXid);
+
+       ResolveRecoveryConflictWithSnapshot(latestRemovedXid, rnode);
+   }
 
    /* If we have a full-page image, restore it and we're done */
    if (record->xl_info & XLR_BKP_BLOCK(0))