Commit 16974ee9 authored by Tom Lane's avatar Tom Lane

Get rid of the former rather baroque mechanism for propagating the values

of ThisStartUpID and RedoRecPtr into new backends.  It's a lot easier just
to make them all grab the values out of shared memory during startup.
This helps to decouple the postmaster from checkpoint execution, which I
need since I'm intending to let the bgwriter do it instead, and it also
fixes a bug in the Win32 port: ThisStartUpID wasn't getting propagated at
all AFAICS.  (Doesn't give me a lot of faith in the amount of testing that
port has gotten.)
parent bb44a7c5
...@@ -8,7 +8,7 @@ ...@@ -8,7 +8,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $PostgreSQL: pgsql/src/backend/access/heap/heapam.c,v 1.167 2004/05/20 15:07:30 tgl Exp $ * $PostgreSQL: pgsql/src/backend/access/heap/heapam.c,v 1.168 2004/05/27 17:12:37 tgl Exp $
* *
* *
* INTERFACE ROUTINES * INTERFACE ROUTINES
...@@ -1902,7 +1902,7 @@ l3: ...@@ -1902,7 +1902,7 @@ l3:
* XLOG stuff: no logging is required as long as we have no * XLOG stuff: no logging is required as long as we have no
* savepoints. For savepoints private log could be used... * savepoints. For savepoints private log could be used...
*/ */
((PageHeader) BufferGetPage(*buffer))->pd_sui = ThisStartUpID; PageSetSUI(BufferGetPage(*buffer), ThisStartUpID);
/* store transaction information of xact marking the tuple */ /* store transaction information of xact marking the tuple */
tuple->t_data->t_infomask &= ~(HEAP_XMAX_COMMITTED | tuple->t_data->t_infomask &= ~(HEAP_XMAX_COMMITTED |
......
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
* Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group * Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group
* Portions Copyright (c) 1994, Regents of the University of California * Portions Copyright (c) 1994, Regents of the University of California
* *
* $PostgreSQL: pgsql/src/backend/access/transam/xlog.c,v 1.142 2004/05/21 16:08:46 tgl Exp $ * $PostgreSQL: pgsql/src/backend/access/transam/xlog.c,v 1.143 2004/05/27 17:12:42 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -166,9 +166,10 @@ XLogRecPtr ProcLastRecEnd = {0, 0}; ...@@ -166,9 +166,10 @@ XLogRecPtr ProcLastRecEnd = {0, 0};
* XLogCtl->Insert.RedoRecPtr, whenever we can safely do so (ie, when we * XLogCtl->Insert.RedoRecPtr, whenever we can safely do so (ie, when we
* hold the Insert lock). See XLogInsert for details. We are also allowed * hold the Insert lock). See XLogInsert for details. We are also allowed
* to update from XLogCtl->Insert.RedoRecPtr if we hold the info_lck; * to update from XLogCtl->Insert.RedoRecPtr if we hold the info_lck;
* see GetRedoRecPtr. * see GetRedoRecPtr. A freshly spawned backend obtains the value during
* InitXLOGAccess.
*/ */
NON_EXEC_STATIC XLogRecPtr RedoRecPtr; static XLogRecPtr RedoRecPtr;
/*---------- /*----------
* Shared-memory data structures for XLOG control * Shared-memory data structures for XLOG control
...@@ -280,10 +281,6 @@ typedef struct XLogCtlData ...@@ -280,10 +281,6 @@ typedef struct XLogCtlData
uint32 XLogCacheBlck; /* highest allocated xlog buffer index */ uint32 XLogCacheBlck; /* highest allocated xlog buffer index */
StartUpID ThisStartUpID; StartUpID ThisStartUpID;
/* This value is not protected by *any* lock... */
/* see SetSavedRedoRecPtr/GetSavedRedoRecPtr */
XLogRecPtr SavedRedoRecPtr;
slock_t info_lck; /* locks shared LogwrtRqst/LogwrtResult */ slock_t info_lck; /* locks shared LogwrtRqst/LogwrtResult */
} XLogCtlData; } XLogCtlData;
...@@ -2893,8 +2890,7 @@ StartupXLOG(void) ...@@ -2893,8 +2890,7 @@ StartupXLOG(void)
else else
ThisStartUpID = checkPoint.ThisStartUpID; ThisStartUpID = checkPoint.ThisStartUpID;
RedoRecPtr = XLogCtl->Insert.RedoRecPtr = RedoRecPtr = XLogCtl->Insert.RedoRecPtr = checkPoint.redo;
XLogCtl->SavedRedoRecPtr = checkPoint.redo;
if (XLByteLT(RecPtr, checkPoint.redo)) if (XLByteLT(RecPtr, checkPoint.redo))
ereport(PANIC, ereport(PANIC,
...@@ -3251,35 +3247,22 @@ ReadCheckpointRecord(XLogRecPtr RecPtr, ...@@ -3251,35 +3247,22 @@ ReadCheckpointRecord(XLogRecPtr RecPtr,
} }
/* /*
* Postmaster uses this to initialize ThisStartUpID & RedoRecPtr from * This must be called during startup of a backend process, except that
* XLogCtlData located in shmem after successful startup. * it need not be called in a standalone backend (which does StartupXLOG
* instead). We need to initialize the local copies of ThisStartUpID and
* RedoRecPtr.
*
* Note: before Postgres 7.5, we went to some effort to keep the postmaster
* process's copies of ThisStartUpID and RedoRecPtr valid too. This was
* unnecessary however, since the postmaster itself never touches XLOG anyway.
*/ */
void void
SetThisStartUpID(void) InitXLOGAccess(void)
{ {
/* ThisStartUpID doesn't change so we need no lock to copy it */
ThisStartUpID = XLogCtl->ThisStartUpID; ThisStartUpID = XLogCtl->ThisStartUpID;
RedoRecPtr = XLogCtl->SavedRedoRecPtr; /* Use GetRedoRecPtr to copy the RedoRecPtr safely */
} (void) GetRedoRecPtr();
/*
* CheckPoint process called by postmaster saves copy of new RedoRecPtr
* in shmem (using SetSavedRedoRecPtr). When checkpointer completes,
* postmaster calls GetSavedRedoRecPtr to update its own copy of RedoRecPtr,
* so that subsequently-spawned backends will start out with a reasonably
* up-to-date local RedoRecPtr. Since these operations are not protected by
* any lock and copying an XLogRecPtr isn't atomic, it's unsafe to use either
* of these routines at other times!
*/
void
SetSavedRedoRecPtr(void)
{
XLogCtl->SavedRedoRecPtr = RedoRecPtr;
}
void
GetSavedRedoRecPtr(void)
{
RedoRecPtr = XLogCtl->SavedRedoRecPtr;
} }
/* /*
......
...@@ -8,7 +8,7 @@ ...@@ -8,7 +8,7 @@
* Portions Copyright (c) 1994, Regents of the University of California * Portions Copyright (c) 1994, Regents of the University of California
* *
* IDENTIFICATION * IDENTIFICATION
* $PostgreSQL: pgsql/src/backend/bootstrap/bootstrap.c,v 1.179 2004/05/21 05:07:56 tgl Exp $ * $PostgreSQL: pgsql/src/backend/bootstrap/bootstrap.c,v 1.180 2004/05/27 17:12:49 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -489,12 +489,12 @@ BootstrapMain(int argc, char *argv[]) ...@@ -489,12 +489,12 @@ BootstrapMain(int argc, char *argv[])
break; break;
case BS_XLOG_CHECKPOINT: case BS_XLOG_CHECKPOINT:
InitXLOGAccess();
CreateCheckPoint(false, false); CreateCheckPoint(false, false);
SetSavedRedoRecPtr(); /* pass redo ptr back to
* postmaster */
proc_exit(0); /* done */ proc_exit(0); /* done */
case BS_XLOG_BGWRITER: case BS_XLOG_BGWRITER:
InitXLOGAccess();
BufferBackgroundWriter(); BufferBackgroundWriter();
proc_exit(0); /* done */ proc_exit(0); /* done */
...@@ -504,6 +504,7 @@ BootstrapMain(int argc, char *argv[]) ...@@ -504,6 +504,7 @@ BootstrapMain(int argc, char *argv[])
proc_exit(0); /* done */ proc_exit(0); /* done */
case BS_XLOG_SHUTDOWN: case BS_XLOG_SHUTDOWN:
InitXLOGAccess();
ShutdownXLOG(0, 0); ShutdownXLOG(0, 0);
DumpFreeSpaceMap(0, 0); DumpFreeSpaceMap(0, 0);
proc_exit(0); /* done */ proc_exit(0); /* done */
......
...@@ -37,7 +37,7 @@ ...@@ -37,7 +37,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $PostgreSQL: pgsql/src/backend/postmaster/postmaster.c,v 1.396 2004/05/27 15:07:41 momjian Exp $ * $PostgreSQL: pgsql/src/backend/postmaster/postmaster.c,v 1.397 2004/05/27 17:12:52 tgl Exp $
* *
* NOTES * NOTES
* *
...@@ -1909,8 +1909,8 @@ reaper(SIGNAL_ARGS) ...@@ -1909,8 +1909,8 @@ reaper(SIGNAL_ARGS)
* trouble... * trouble...
*/ */
win32_RemoveChild(pid); win32_RemoveChild(pid);
#endif #endif /* WIN32 */
#endif #endif /* HAVE_WAITPID */
/* /*
* Check if this child was the statistics collector. If so, try to * Check if this child was the statistics collector. If so, try to
...@@ -1953,14 +1953,9 @@ reaper(SIGNAL_ARGS) ...@@ -1953,14 +1953,9 @@ reaper(SIGNAL_ARGS)
StartupPID = 0; StartupPID = 0;
/* /*
* Startup succeeded - remember its ID and RedoRecPtr. * Startup succeeded - we are done with system startup or recovery.
*
* NB: this MUST happen before we fork a checkpoint or shutdown
* subprocess, else they will have wrong local ThisStartUpId.
*/ */
SetThisStartUpID(); FatalError = false;
FatalError = false; /* done with recovery */
/* /*
* Arrange for first checkpoint to occur after standard delay. * Arrange for first checkpoint to occur after standard delay.
...@@ -2073,8 +2068,6 @@ CleanupProc(int pid, ...@@ -2073,8 +2068,6 @@ CleanupProc(int pid,
if (!FatalError) if (!FatalError)
{ {
checkpointed = time(NULL); checkpointed = time(NULL);
/* Update RedoRecPtr for future child backends */
GetSavedRedoRecPtr();
} }
} }
else if (pid == BgWriterPID) else if (pid == BgWriterPID)
...@@ -3287,7 +3280,6 @@ postmaster_error(const char *fmt,...) ...@@ -3287,7 +3280,6 @@ postmaster_error(const char *fmt,...)
* functions * functions
*/ */
#include "storage/spin.h" #include "storage/spin.h"
extern XLogRecPtr RedoRecPtr;
extern XLogwrtResult LogwrtResult; extern XLogwrtResult LogwrtResult;
extern slock_t *ShmemLock; extern slock_t *ShmemLock;
extern slock_t *ShmemIndexLock; extern slock_t *ShmemIndexLock;
...@@ -3351,7 +3343,6 @@ write_backend_variables(Port *port) ...@@ -3351,7 +3343,6 @@ write_backend_variables(Port *port)
} }
write_var(MyCancelKey, fp); write_var(MyCancelKey, fp);
write_var(RedoRecPtr, fp);
write_var(LogwrtResult, fp); write_var(LogwrtResult, fp);
write_var(UsedShmemSegID, fp); write_var(UsedShmemSegID, fp);
...@@ -3416,7 +3407,6 @@ read_backend_variables(unsigned long id, Port *port) ...@@ -3416,7 +3407,6 @@ read_backend_variables(unsigned long id, Port *port)
} }
read_var(MyCancelKey, fp); read_var(MyCancelKey, fp);
read_var(RedoRecPtr, fp);
read_var(LogwrtResult, fp); read_var(LogwrtResult, fp);
read_var(UsedShmemSegID, fp); read_var(UsedShmemSegID, fp);
......
...@@ -8,7 +8,7 @@ ...@@ -8,7 +8,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $PostgreSQL: pgsql/src/backend/utils/init/postinit.c,v 1.131 2003/12/12 18:45:09 petere Exp $ * $PostgreSQL: pgsql/src/backend/utils/init/postinit.c,v 1.132 2004/05/27 17:12:54 tgl Exp $
* *
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
...@@ -325,6 +325,13 @@ InitPostgres(const char *dbname, const char *username) ...@@ -325,6 +325,13 @@ InitPostgres(const char *dbname, const char *username)
*/ */
AmiTransactionOverride(bootstrap); AmiTransactionOverride(bootstrap);
/*
* Initialize local process's access to XLOG. In bootstrap case
* we may skip this since StartupXLOG() was run instead.
*/
if (!bootstrap)
InitXLOGAccess();
/* /*
* Initialize the relation descriptor cache. This must create at * Initialize the relation descriptor cache. This must create at
* least the minimum set of "nailed-in" cache entries. No catalog * least the minimum set of "nailed-in" cache entries. No catalog
......
...@@ -6,7 +6,7 @@ ...@@ -6,7 +6,7 @@
* Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group * Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group
* Portions Copyright (c) 1994, Regents of the University of California * Portions Copyright (c) 1994, Regents of the University of California
* *
* $PostgreSQL: pgsql/src/include/access/xlog.h,v 1.49 2004/02/11 22:55:25 tgl Exp $ * $PostgreSQL: pgsql/src/include/access/xlog.h,v 1.50 2004/05/27 17:12:57 tgl Exp $
*/ */
#ifndef XLOG_H #ifndef XLOG_H
#define XLOG_H #define XLOG_H
...@@ -230,11 +230,9 @@ extern void XLOGPathInit(void); ...@@ -230,11 +230,9 @@ extern void XLOGPathInit(void);
extern void BootStrapXLOG(void); extern void BootStrapXLOG(void);
extern void StartupXLOG(void); extern void StartupXLOG(void);
extern void ShutdownXLOG(int code, Datum arg); extern void ShutdownXLOG(int code, Datum arg);
extern void InitXLOGAccess(void);
extern void CreateCheckPoint(bool shutdown, bool force); extern void CreateCheckPoint(bool shutdown, bool force);
extern void SetThisStartUpID(void);
extern void XLogPutNextOid(Oid nextOid); extern void XLogPutNextOid(Oid nextOid);
extern void SetSavedRedoRecPtr(void);
extern void GetSavedRedoRecPtr(void);
extern XLogRecPtr GetRedoRecPtr(void); extern XLogRecPtr GetRedoRecPtr(void);
/* in storage/ipc/sinval.c, but don't want to declare in sinval.h because /* in storage/ipc/sinval.c, but don't want to declare in sinval.h because
......
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