Commit b5310e4f authored by Fujii Masao's avatar Fujii Masao

Remove non-fast promotion.

When fast promotion was supported in 9.3, non-fast promotion became
undocumented feature and it's basically not available for ordinary users.
However we decided not to remove non-fast promotion at that moment,
to leave it for a release or two for debugging purpose or as an emergency
method because fast promotion might have some issues, and then to
remove it later. Now, several versions were released since that decision
and there is no longer reason to keep supporting non-fast promotion.
Therefore this commit removes non-fast promotion.

Author: Fujii Masao
Reviewed-by: Hamid Akhtar, Kyotaro Horiguchi
Discussion: https://postgr.es/m/76066434-648f-f567-437b-54853b43398f@oss.nttdata.com
parent 9878b643
...@@ -299,9 +299,6 @@ bool wal_receiver_create_temp_slot = false; ...@@ -299,9 +299,6 @@ bool wal_receiver_create_temp_slot = false;
/* are we currently in standby mode? */ /* are we currently in standby mode? */
bool StandbyMode = false; bool StandbyMode = false;
/* whether request for fast promotion has been made yet */
static bool fast_promote = false;
/* /*
* if recoveryStopsBefore/After returns true, it saves information of the stop * if recoveryStopsBefore/After returns true, it saves information of the stop
* point here * point here
...@@ -6322,7 +6319,7 @@ StartupXLOG(void) ...@@ -6322,7 +6319,7 @@ StartupXLOG(void)
DBState dbstate_at_startup; DBState dbstate_at_startup;
XLogReaderState *xlogreader; XLogReaderState *xlogreader;
XLogPageReadPrivate private; XLogPageReadPrivate private;
bool fast_promoted = false; bool promoted = false;
struct stat st; struct stat st;
/* /*
...@@ -7727,14 +7724,14 @@ StartupXLOG(void) ...@@ -7727,14 +7724,14 @@ StartupXLOG(void)
* the rule that TLI only changes in shutdown checkpoints, which * the rule that TLI only changes in shutdown checkpoints, which
* allows some extra error checking in xlog_redo. * allows some extra error checking in xlog_redo.
* *
* In fast promotion, only create a lightweight end-of-recovery record * In promotion, only create a lightweight end-of-recovery record
* instead of a full checkpoint. A checkpoint is requested later, * instead of a full checkpoint. A checkpoint is requested later,
* after we're fully out of recovery mode and already accepting * after we're fully out of recovery mode and already accepting
* queries. * queries.
*/ */
if (bgwriterLaunched) if (bgwriterLaunched)
{ {
if (fast_promote) if (LocalPromoteIsTriggered)
{ {
checkPointLoc = ControlFile->checkPoint; checkPointLoc = ControlFile->checkPoint;
...@@ -7745,7 +7742,7 @@ StartupXLOG(void) ...@@ -7745,7 +7742,7 @@ StartupXLOG(void)
record = ReadCheckpointRecord(xlogreader, checkPointLoc, 1, false); record = ReadCheckpointRecord(xlogreader, checkPointLoc, 1, false);
if (record != NULL) if (record != NULL)
{ {
fast_promoted = true; promoted = true;
/* /*
* Insert a special WAL record to mark the end of * Insert a special WAL record to mark the end of
...@@ -7762,7 +7759,7 @@ StartupXLOG(void) ...@@ -7762,7 +7759,7 @@ StartupXLOG(void)
} }
} }
if (!fast_promoted) if (!promoted)
RequestCheckpoint(CHECKPOINT_END_OF_RECOVERY | RequestCheckpoint(CHECKPOINT_END_OF_RECOVERY |
CHECKPOINT_IMMEDIATE | CHECKPOINT_IMMEDIATE |
CHECKPOINT_WAIT); CHECKPOINT_WAIT);
...@@ -7953,12 +7950,12 @@ StartupXLOG(void) ...@@ -7953,12 +7950,12 @@ StartupXLOG(void)
WalSndWakeup(); WalSndWakeup();
/* /*
* If this was a fast promotion, request an (online) checkpoint now. This * If this was a promotion, request an (online) checkpoint now. This
* isn't required for consistency, but the last restartpoint might be far * isn't required for consistency, but the last restartpoint might be far
* back, and in case of a crash, recovering from it might take a longer * back, and in case of a crash, recovering from it might take a longer
* than is appropriate now that we're not in standby mode anymore. * than is appropriate now that we're not in standby mode anymore.
*/ */
if (fast_promoted) if (promoted)
RequestCheckpoint(CHECKPOINT_FORCE); RequestCheckpoint(CHECKPOINT_FORCE);
} }
...@@ -12592,29 +12589,10 @@ CheckForStandbyTrigger(void) ...@@ -12592,29 +12589,10 @@ CheckForStandbyTrigger(void)
if (LocalPromoteIsTriggered) if (LocalPromoteIsTriggered)
return true; return true;
if (IsPromoteSignaled()) if (IsPromoteSignaled() && CheckPromoteSignal())
{ {
/*
* In 9.1 and 9.2 the postmaster unlinked the promote file inside the
* signal handler. It now leaves the file in place and lets the
* Startup process do the unlink. This allows Startup to know whether
* it should create a full checkpoint before starting up (fallback
* mode). Fast promotion takes precedence.
*/
if (stat(PROMOTE_SIGNAL_FILE, &stat_buf) == 0)
{
unlink(PROMOTE_SIGNAL_FILE);
unlink(FALLBACK_PROMOTE_SIGNAL_FILE);
fast_promote = true;
}
else if (stat(FALLBACK_PROMOTE_SIGNAL_FILE, &stat_buf) == 0)
{
unlink(FALLBACK_PROMOTE_SIGNAL_FILE);
fast_promote = false;
}
ereport(LOG, (errmsg("received promote request"))); ereport(LOG, (errmsg("received promote request")));
RemovePromoteSignalFiles();
ResetPromoteSignaled(); ResetPromoteSignaled();
SetPromoteIsTriggered(); SetPromoteIsTriggered();
return true; return true;
...@@ -12629,7 +12607,6 @@ CheckForStandbyTrigger(void) ...@@ -12629,7 +12607,6 @@ CheckForStandbyTrigger(void)
(errmsg("promote trigger file found: %s", PromoteTriggerFile))); (errmsg("promote trigger file found: %s", PromoteTriggerFile)));
unlink(PromoteTriggerFile); unlink(PromoteTriggerFile);
SetPromoteIsTriggered(); SetPromoteIsTriggered();
fast_promote = true;
return true; return true;
} }
else if (errno != ENOENT) else if (errno != ENOENT)
...@@ -12648,20 +12625,17 @@ void ...@@ -12648,20 +12625,17 @@ void
RemovePromoteSignalFiles(void) RemovePromoteSignalFiles(void)
{ {
unlink(PROMOTE_SIGNAL_FILE); unlink(PROMOTE_SIGNAL_FILE);
unlink(FALLBACK_PROMOTE_SIGNAL_FILE);
} }
/* /*
* Check to see if a promote request has arrived. Should be * Check to see if a promote request has arrived.
* called by postmaster after receiving SIGUSR1.
*/ */
bool bool
CheckPromoteSignal(void) CheckPromoteSignal(void)
{ {
struct stat stat_buf; struct stat stat_buf;
if (stat(PROMOTE_SIGNAL_FILE, &stat_buf) == 0 || if (stat(PROMOTE_SIGNAL_FILE, &stat_buf) == 0)
stat(FALLBACK_PROMOTE_SIGNAL_FILE, &stat_buf) == 0)
return true; return true;
return false; return false;
......
...@@ -5333,7 +5333,12 @@ sigusr1_handler(SIGNAL_ARGS) ...@@ -5333,7 +5333,12 @@ sigusr1_handler(SIGNAL_ARGS)
pmState == PM_HOT_STANDBY || pmState == PM_WAIT_READONLY) && pmState == PM_HOT_STANDBY || pmState == PM_WAIT_READONLY) &&
CheckPromoteSignal()) CheckPromoteSignal())
{ {
/* Tell startup process to finish recovery */ /*
* Tell startup process to finish recovery.
*
* Leave the promote signal file in place and let the Startup
* process do the unlink.
*/
signal_child(StartupPID, SIGUSR2); signal_child(StartupPID, SIGUSR2);
} }
......
...@@ -1195,11 +1195,6 @@ do_promote(void) ...@@ -1195,11 +1195,6 @@ do_promote(void)
exit(1); exit(1);
} }
/*
* For 9.3 onwards, "fast" promotion is performed. Promotion with a full
* checkpoint is still possible by writing a file called
* "fallback_promote" instead of "promote"
*/
snprintf(promote_file, MAXPGPATH, "%s/promote", pg_data); snprintf(promote_file, MAXPGPATH, "%s/promote", pg_data);
if ((prmfile = fopen(promote_file, "w")) == NULL) if ((prmfile = fopen(promote_file, "w")) == NULL)
......
...@@ -394,6 +394,5 @@ extern SessionBackupState get_backup_status(void); ...@@ -394,6 +394,5 @@ extern SessionBackupState get_backup_status(void);
/* files to signal promotion to primary */ /* files to signal promotion to primary */
#define PROMOTE_SIGNAL_FILE "promote" #define PROMOTE_SIGNAL_FILE "promote"
#define FALLBACK_PROMOTE_SIGNAL_FILE "fallback_promote"
#endif /* XLOG_H */ #endif /* XLOG_H */
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