mirror of
https://github.com/postgres/postgres.git
synced 2025-08-05 07:41:25 +03:00
Remove exclusive backup mode
Exclusive-mode backups have been deprecated since 9.6 (when non-exclusive backups were introduced) due to the issues they can cause should the system crash while one is running and generally because non-exclusive provides a much better interface. Further, exclusive backup mode wasn't really being tested (nor was most of the related code- like being able to log in just to stop an exclusive backup and the bits of the state machine related to that) and having to possibly deal with an exclusive backup and the backup_label file existing during pg_basebackup, pg_rewind, etc, added other complexities that we are better off without. This patch removes the exclusive backup mode, the various special cases for dealing with it, and greatly simplifies the online backup code and documentation. Authors: David Steele, Nathan Bossart Reviewed-by: Chapman Flack Discussion: https://postgr.es/m/ac7339ca-3718-3c93-929f-99e725d1172c@pgmasters.net https://postgr.es/m/CAHg+QDfiM+WU61tF6=nPZocMZvHDzCK47Kneyb0ZRULYzV5sKQ@mail.gmail.com
This commit is contained in:
@@ -1025,7 +1025,6 @@ static void
|
||||
do_stop(void)
|
||||
{
|
||||
pgpid_t pid;
|
||||
struct stat statbuf;
|
||||
|
||||
pid = get_pgpid(false);
|
||||
|
||||
@@ -1058,20 +1057,6 @@ do_stop(void)
|
||||
}
|
||||
else
|
||||
{
|
||||
/*
|
||||
* If backup_label exists, an online backup is running. Warn the user
|
||||
* that smart shutdown will wait for it to finish. However, if the
|
||||
* server is in archive recovery, we're recovering from an online
|
||||
* backup instead of performing one.
|
||||
*/
|
||||
if (shutdown_mode == SMART_MODE &&
|
||||
stat(backup_file, &statbuf) == 0 &&
|
||||
get_control_dbstate() != DB_IN_ARCHIVE_RECOVERY)
|
||||
{
|
||||
print_msg(_("WARNING: online backup mode is active\n"
|
||||
"Shutdown will not complete until pg_stop_backup() is called.\n\n"));
|
||||
}
|
||||
|
||||
print_msg(_("waiting for server to shut down..."));
|
||||
|
||||
if (!wait_for_postmaster_stop())
|
||||
@@ -1099,7 +1084,6 @@ static void
|
||||
do_restart(void)
|
||||
{
|
||||
pgpid_t pid;
|
||||
struct stat statbuf;
|
||||
|
||||
pid = get_pgpid(false);
|
||||
|
||||
@@ -1134,20 +1118,6 @@ do_restart(void)
|
||||
exit(1);
|
||||
}
|
||||
|
||||
/*
|
||||
* If backup_label exists, an online backup is running. Warn the user
|
||||
* that smart shutdown will wait for it to finish. However, if the
|
||||
* server is in archive recovery, we're recovering from an online
|
||||
* backup instead of performing one.
|
||||
*/
|
||||
if (shutdown_mode == SMART_MODE &&
|
||||
stat(backup_file, &statbuf) == 0 &&
|
||||
get_control_dbstate() != DB_IN_ARCHIVE_RECOVERY)
|
||||
{
|
||||
print_msg(_("WARNING: online backup mode is active\n"
|
||||
"Shutdown will not complete until pg_stop_backup() is called.\n\n"));
|
||||
}
|
||||
|
||||
print_msg(_("waiting for server to shut down..."));
|
||||
|
||||
/* always wait for restart */
|
||||
|
Reference in New Issue
Block a user