diff --git a/src/backend/access/transam/xlog.c b/src/backend/access/transam/xlog.c index e77af22aebc31e82bd2807e6abf02ee3d5a9ecbc..3c9aeaec1e7e839bf08cf5a9575be495707cc2ed 100644 --- a/src/backend/access/transam/xlog.c +++ b/src/backend/access/transam/xlog.c @@ -5323,7 +5323,7 @@ static void exitArchiveRecovery(TimeLineID endTLI, XLogSegNo endLogSegNo) { char recoveryPath[MAXPGPATH]; - char xlogpath[MAXPGPATH]; + char xlogfname[MAXFNAMELEN]; /* * We are no longer in archive recovery state. @@ -5351,17 +5351,19 @@ exitArchiveRecovery(TimeLineID endTLI, XLogSegNo endLogSegNo) * for the new timeline. * * Notify the archiver that the last WAL segment of the old timeline is - * ready to copy to archival storage. Otherwise, it is not archived for a - * while. + * ready to copy to archival storage if its .done file doesn't exist + * (e.g., if it's the restored WAL file, it's expected to have .done file). + * Otherwise, it is not archived for a while. */ if (endTLI != ThisTimeLineID) { XLogFileCopy(endLogSegNo, endTLI, endLogSegNo); + /* Create .ready file only when neither .ready nor .done files exist */ if (XLogArchivingActive()) { - XLogFileName(xlogpath, endTLI, endLogSegNo); - XLogArchiveNotify(xlogpath); + XLogFileName(xlogfname, endTLI, endLogSegNo); + XLogArchiveCheckDone(xlogfname); } } @@ -5369,8 +5371,8 @@ exitArchiveRecovery(TimeLineID endTLI, XLogSegNo endLogSegNo) * Let's just make real sure there are not .ready or .done flags posted * for the new segment. */ - XLogFileName(xlogpath, ThisTimeLineID, endLogSegNo); - XLogArchiveCleanup(xlogpath); + XLogFileName(xlogfname, ThisTimeLineID, endLogSegNo); + XLogArchiveCleanup(xlogfname); /* * Since there might be a partial WAL segment named RECOVERYXLOG, get rid