]> git.ipfire.org Git - thirdparty/postgresql.git/commitdiff
Fix bug in WAL replay of COMMIT_TS_SETTS record.
authorFujii Masao <fujii@postgresql.org>
Thu, 25 Mar 2021 02:23:30 +0000 (11:23 +0900)
committerFujii Masao <fujii@postgresql.org>
Thu, 25 Mar 2021 02:24:20 +0000 (11:24 +0900)
Previously the WAL replay of COMMIT_TS_SETTS record called
TransactionTreeSetCommitTsData() with the argument write_xlog=true,
which generated and wrote new COMMIT_TS_SETTS record.
This should not be acceptable because it's during recovery.

This commit fixes the WAL replay of COMMIT_TS_SETTS record
so that it calls TransactionTreeSetCommitTsData() with write_xlog=false
and doesn't generate new WAL during recovery.

Back-patch to all supported branches.

Reported-by: lx zou <zoulx1982@163.com>
Author: Fujii Masao
Reviewed-by: Alvaro Herrera
Discussion: https://postgr.es/m/16931-620d0f2fdc6108f1@postgresql.org

src/backend/access/transam/commit_ts.c

index 87a69f4c21029d7d896ae3685e4218ab077743f3..baa0513947e734aa876eda180db641e7f6791f1a 100644 (file)
@@ -1024,7 +1024,7 @@ commit_ts_redo(XLogReaderState *record)
                        subxids = NULL;
 
                TransactionTreeSetCommitTsData(setts->mainxid, nsubxids, subxids,
-                                                                          setts->timestamp, setts->nodeid, true);
+                                                                          setts->timestamp, setts->nodeid, false);
                if (subxids)
                        pfree(subxids);
        }