Commit 5ed6fff6 authored by Tom Lane's avatar Tom Lane

Make logging about multixact wraparound protection less chatty.

The original messaging design, introduced in commit 068cfadf, seems too
chatty now that some time has elapsed since the bug fix; most installations
will be in good shape and don't really need a reminder about this on every
postmaster start.

Hence, arrange to suppress the "wraparound protections are now enabled"
message during startup (specifically, during the TrimMultiXact() call).
The message will still appear if protection becomes effective at some
later point.

Discussion: https://postgr.es/m/17211.1489189214@sss.pgh.pa.us
parent c6c099d3
...@@ -363,7 +363,7 @@ static void ExtendMultiXactOffset(MultiXactId multi); ...@@ -363,7 +363,7 @@ static void ExtendMultiXactOffset(MultiXactId multi);
static void ExtendMultiXactMember(MultiXactOffset offset, int nmembers); static void ExtendMultiXactMember(MultiXactOffset offset, int nmembers);
static bool MultiXactOffsetWouldWrap(MultiXactOffset boundary, static bool MultiXactOffsetWouldWrap(MultiXactOffset boundary,
MultiXactOffset start, uint32 distance); MultiXactOffset start, uint32 distance);
static bool SetOffsetVacuumLimit(void); static bool SetOffsetVacuumLimit(bool is_startup);
static bool find_multixact_start(MultiXactId multi, MultiXactOffset *result); static bool find_multixact_start(MultiXactId multi, MultiXactOffset *result);
static void WriteMZeroPageXlogRec(int pageno, uint8 info); static void WriteMZeroPageXlogRec(int pageno, uint8 info);
static void WriteMTruncateXlogRec(Oid oldestMultiDB, static void WriteMTruncateXlogRec(Oid oldestMultiDB,
...@@ -2095,7 +2095,7 @@ TrimMultiXact(void) ...@@ -2095,7 +2095,7 @@ TrimMultiXact(void)
LWLockRelease(MultiXactGenLock); LWLockRelease(MultiXactGenLock);
/* Now compute how far away the next members wraparound is. */ /* Now compute how far away the next members wraparound is. */
SetMultiXactIdLimit(oldestMXact, oldestMXactDB); SetMultiXactIdLimit(oldestMXact, oldestMXactDB, true);
} }
/* /*
...@@ -2186,9 +2186,13 @@ MultiXactSetNextMXact(MultiXactId nextMulti, ...@@ -2186,9 +2186,13 @@ MultiXactSetNextMXact(MultiXactId nextMulti,
* Determine the last safe MultiXactId to allocate given the currently oldest * Determine the last safe MultiXactId to allocate given the currently oldest
* datminmxid (ie, the oldest MultiXactId that might exist in any database * datminmxid (ie, the oldest MultiXactId that might exist in any database
* of our cluster), and the OID of the (or a) database with that value. * of our cluster), and the OID of the (or a) database with that value.
*
* is_startup is true when we are just starting the cluster, false when we
* are updating state in a running cluster. This only affects log messages.
*/ */
void void
SetMultiXactIdLimit(MultiXactId oldest_datminmxid, Oid oldest_datoid) SetMultiXactIdLimit(MultiXactId oldest_datminmxid, Oid oldest_datoid,
bool is_startup)
{ {
MultiXactId multiVacLimit; MultiXactId multiVacLimit;
MultiXactId multiWarnLimit; MultiXactId multiWarnLimit;
...@@ -2277,7 +2281,7 @@ SetMultiXactIdLimit(MultiXactId oldest_datminmxid, Oid oldest_datoid) ...@@ -2277,7 +2281,7 @@ SetMultiXactIdLimit(MultiXactId oldest_datminmxid, Oid oldest_datoid)
Assert(!InRecovery); Assert(!InRecovery);
/* Set limits for offset vacuum. */ /* Set limits for offset vacuum. */
needs_offset_vacuum = SetOffsetVacuumLimit(); needs_offset_vacuum = SetOffsetVacuumLimit(is_startup);
/* /*
* If past the autovacuum force point, immediately signal an autovac * If past the autovacuum force point, immediately signal an autovac
...@@ -2370,7 +2374,7 @@ MultiXactAdvanceOldest(MultiXactId oldestMulti, Oid oldestMultiDB) ...@@ -2370,7 +2374,7 @@ MultiXactAdvanceOldest(MultiXactId oldestMulti, Oid oldestMultiDB)
Assert(InRecovery); Assert(InRecovery);
if (MultiXactIdPrecedes(MultiXactState->oldestMultiXactId, oldestMulti)) if (MultiXactIdPrecedes(MultiXactState->oldestMultiXactId, oldestMulti))
SetMultiXactIdLimit(oldestMulti, oldestMultiDB); SetMultiXactIdLimit(oldestMulti, oldestMultiDB, false);
} }
/* /*
...@@ -2537,7 +2541,7 @@ GetOldestMultiXactId(void) ...@@ -2537,7 +2541,7 @@ GetOldestMultiXactId(void)
* otherwise. * otherwise.
*/ */
static bool static bool
SetOffsetVacuumLimit(void) SetOffsetVacuumLimit(bool is_startup)
{ {
MultiXactId oldestMultiXactId; MultiXactId oldestMultiXactId;
MultiXactId nextMXact; MultiXactId nextMXact;
...@@ -2619,9 +2623,10 @@ SetOffsetVacuumLimit(void) ...@@ -2619,9 +2623,10 @@ SetOffsetVacuumLimit(void)
/* always leave one segment before the wraparound point */ /* always leave one segment before the wraparound point */
offsetStopLimit -= (MULTIXACT_MEMBERS_PER_PAGE * SLRU_PAGES_PER_SEGMENT); offsetStopLimit -= (MULTIXACT_MEMBERS_PER_PAGE * SLRU_PAGES_PER_SEGMENT);
if (!prevOldestOffsetKnown && IsUnderPostmaster) if (!prevOldestOffsetKnown && !is_startup)
ereport(LOG, ereport(LOG,
(errmsg("MultiXact member wraparound protections are now enabled"))); (errmsg("MultiXact member wraparound protections are now enabled")));
ereport(DEBUG1, ereport(DEBUG1,
(errmsg("MultiXact member stop limit is now %u based on MultiXact %u", (errmsg("MultiXact member stop limit is now %u based on MultiXact %u",
offsetStopLimit, oldestMultiXactId))); offsetStopLimit, oldestMultiXactId)));
...@@ -3312,7 +3317,7 @@ multixact_redo(XLogReaderState *record) ...@@ -3312,7 +3317,7 @@ multixact_redo(XLogReaderState *record)
* Advance the horizon values, so they're current at the end of * Advance the horizon values, so they're current at the end of
* recovery. * recovery.
*/ */
SetMultiXactIdLimit(xlrec.endTruncOff, xlrec.oldestMultiDB); SetMultiXactIdLimit(xlrec.endTruncOff, xlrec.oldestMultiDB, false);
PerformMembersTruncation(xlrec.startTruncMemb, xlrec.endTruncMemb); PerformMembersTruncation(xlrec.startTruncMemb, xlrec.endTruncMemb);
......
...@@ -4995,7 +4995,7 @@ BootStrapXLOG(void) ...@@ -4995,7 +4995,7 @@ BootStrapXLOG(void)
ShmemVariableCache->oidCount = 0; ShmemVariableCache->oidCount = 0;
MultiXactSetNextMXact(checkPoint.nextMulti, checkPoint.nextMultiOffset); MultiXactSetNextMXact(checkPoint.nextMulti, checkPoint.nextMultiOffset);
SetTransactionIdLimit(checkPoint.oldestXid, checkPoint.oldestXidDB); SetTransactionIdLimit(checkPoint.oldestXid, checkPoint.oldestXidDB);
SetMultiXactIdLimit(checkPoint.oldestMulti, checkPoint.oldestMultiDB); SetMultiXactIdLimit(checkPoint.oldestMulti, checkPoint.oldestMultiDB, true);
SetCommitTsLimit(InvalidTransactionId, InvalidTransactionId); SetCommitTsLimit(InvalidTransactionId, InvalidTransactionId);
/* Set up the XLOG page header */ /* Set up the XLOG page header */
...@@ -6597,7 +6597,7 @@ StartupXLOG(void) ...@@ -6597,7 +6597,7 @@ StartupXLOG(void)
ShmemVariableCache->oidCount = 0; ShmemVariableCache->oidCount = 0;
MultiXactSetNextMXact(checkPoint.nextMulti, checkPoint.nextMultiOffset); MultiXactSetNextMXact(checkPoint.nextMulti, checkPoint.nextMultiOffset);
SetTransactionIdLimit(checkPoint.oldestXid, checkPoint.oldestXidDB); SetTransactionIdLimit(checkPoint.oldestXid, checkPoint.oldestXidDB);
SetMultiXactIdLimit(checkPoint.oldestMulti, checkPoint.oldestMultiDB); SetMultiXactIdLimit(checkPoint.oldestMulti, checkPoint.oldestMultiDB, true);
SetCommitTsLimit(checkPoint.oldestCommitTsXid, SetCommitTsLimit(checkPoint.oldestCommitTsXid,
checkPoint.newestCommitTsXid); checkPoint.newestCommitTsXid);
XLogCtl->ckptXidEpoch = checkPoint.nextXidEpoch; XLogCtl->ckptXidEpoch = checkPoint.nextXidEpoch;
......
...@@ -1205,7 +1205,7 @@ vac_truncate_clog(TransactionId frozenXID, ...@@ -1205,7 +1205,7 @@ vac_truncate_clog(TransactionId frozenXID,
* signalling twice? * signalling twice?
*/ */
SetTransactionIdLimit(frozenXID, oldestxid_datoid); SetTransactionIdLimit(frozenXID, oldestxid_datoid);
SetMultiXactIdLimit(minMulti, minmulti_datoid); SetMultiXactIdLimit(minMulti, minmulti_datoid, false);
} }
......
...@@ -127,7 +127,8 @@ extern void StartupMultiXact(void); ...@@ -127,7 +127,8 @@ extern void StartupMultiXact(void);
extern void TrimMultiXact(void); extern void TrimMultiXact(void);
extern void ShutdownMultiXact(void); extern void ShutdownMultiXact(void);
extern void SetMultiXactIdLimit(MultiXactId oldest_datminmxid, extern void SetMultiXactIdLimit(MultiXactId oldest_datminmxid,
Oid oldest_datoid); Oid oldest_datoid,
bool is_startup);
extern void MultiXactGetCheckptMulti(bool is_shutdown, extern void MultiXactGetCheckptMulti(bool is_shutdown,
MultiXactId *nextMulti, MultiXactId *nextMulti,
MultiXactOffset *nextMultiOffset, MultiXactOffset *nextMultiOffset,
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment