aboutsummaryrefslogtreecommitdiff
path: root/src/backend/access/transam/xlog.c
diff options
context:
space:
mode:
authorRobert Haas <rhaas@postgresql.org>2021-01-27 12:20:46 -0500
committerRobert Haas <rhaas@postgresql.org>2021-01-27 12:20:46 -0500
commit1f113abdf87cd085dee3927960bb4f70442b7250 (patch)
treeb10b455096db4ad3a6471cf52f6ddec219462b9c /src/backend/access/transam/xlog.c
parente42b3c3bd6a9c6233ac4c8a2e9b040367ba2f97c (diff)
downloadpostgresql-1f113abdf87cd085dee3927960bb4f70442b7250.tar.gz
postgresql-1f113abdf87cd085dee3927960bb4f70442b7250.zip
Move StartupCLOG() calls to just after we initialize ShmemVariableCache.
Previously, the hot_standby=off code path did this at end of recovery, while the hot_standby=on code path did it at the beginning of recovery. It's better to do this in only one place because (a) it's simpler, (b) StartupCLOG() is trivial so trying to postpone the work isn't useful, and (c) this will make it possible to simplify some other logic. Patch by me, reviewed by Heikki Linnakangas. Discussion: http://postgr.es/m/CA+TgmoZYig9+AQodhF5sRXuKkJ=RgFDugLr3XX_dz_F-p=TwTg@mail.gmail.com
Diffstat (limited to 'src/backend/access/transam/xlog.c')
-rw-r--r--src/backend/access/transam/xlog.c17
1 files changed, 10 insertions, 7 deletions
diff --git a/src/backend/access/transam/xlog.c b/src/backend/access/transam/xlog.c
index cc007b8963e..236a66f6387 100644
--- a/src/backend/access/transam/xlog.c
+++ b/src/backend/access/transam/xlog.c
@@ -6856,6 +6856,13 @@ StartupXLOG(void)
StartupReorderBuffer();
/*
+ * Startup CLOG. This must be done after ShmemVariableCache->nextXid
+ * has been initialized and before we accept connections or begin WAL
+ * replay.
+ */
+ StartupCLOG();
+
+ /*
* Startup MultiXact. We need to do this early to be able to replay
* truncations.
*/
@@ -7125,11 +7132,10 @@ StartupXLOG(void)
ProcArrayInitRecovery(XidFromFullTransactionId(ShmemVariableCache->nextXid));
/*
- * Startup commit log and subtrans only. MultiXact and commit
+ * Startup subtrans only. CLOG, MultiXact and commit
* timestamp have already been started up and other SLRUs are not
* maintained during recovery and need not be started yet.
*/
- StartupCLOG();
StartupSUBTRANS(oldestActiveXID);
/*
@@ -7945,14 +7951,11 @@ StartupXLOG(void)
LWLockRelease(ProcArrayLock);
/*
- * Start up the commit log and subtrans, if not already done for hot
- * standby. (commit timestamps are started below, if necessary.)
+ * Start up subtrans, if not already done for hot standby. (commit
+ * timestamps are started below, if necessary.)
*/
if (standbyState == STANDBY_DISABLED)
- {
- StartupCLOG();
StartupSUBTRANS(oldestActiveXID);
- }
/*
* Perform end of recovery actions for any SLRUs that need it.