mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Fix autovacuum launcher shutdown sequence
It was previously possible to have the launcher re-execute its main loop before shutting down if some other signal was received or an error occurred after getting SIGTERM, as reported by Qingqing Zhou. While investigating, Tom Lane further noticed that if autovacuum had been disabled in the config file, it would misbehave by trying to start a new worker instead of bailing out immediately -- it would consider itself as invoked in emergency mode. Fix both problems by checking the shutdown flag in a few more places. These problems have existed since autovacuum was introduced, so backpatch all the way back.
This commit is contained in:
		| @@ -533,6 +533,10 @@ AutoVacLauncherMain(int argc, char *argv[]) | |||||||
| 		/* Now we can allow interrupts again */ | 		/* Now we can allow interrupts again */ | ||||||
| 		RESUME_INTERRUPTS(); | 		RESUME_INTERRUPTS(); | ||||||
|  |  | ||||||
|  | 		/* if in shutdown mode, no need for anything further; just go away */ | ||||||
|  | 		if (got_SIGTERM) | ||||||
|  | 			goto shutdown; | ||||||
|  |  | ||||||
| 		/* | 		/* | ||||||
| 		 * Sleep at least 1 second after any error.  We don't want to be | 		 * Sleep at least 1 second after any error.  We don't want to be | ||||||
| 		 * filling the error logs as fast as we can. | 		 * filling the error logs as fast as we can. | ||||||
| @@ -568,9 +572,13 @@ AutoVacLauncherMain(int argc, char *argv[]) | |||||||
| 	SetConfigOption("default_transaction_isolation", "read committed", | 	SetConfigOption("default_transaction_isolation", "read committed", | ||||||
| 					PGC_SUSET, PGC_S_OVERRIDE); | 					PGC_SUSET, PGC_S_OVERRIDE); | ||||||
|  |  | ||||||
| 	/* in emergency mode, just start a worker and go away */ | 	/* | ||||||
|  | 	 * In emergency mode, just start a worker (unless shutdown was requested) | ||||||
|  | 	 * and go away. | ||||||
|  | 	 */ | ||||||
| 	if (!AutoVacuumingActive()) | 	if (!AutoVacuumingActive()) | ||||||
| 	{ | 	{ | ||||||
|  | 		if (!got_SIGTERM) | ||||||
| 			do_start_worker(); | 			do_start_worker(); | ||||||
| 		proc_exit(0);			/* done */ | 		proc_exit(0);			/* done */ | ||||||
| 	} | 	} | ||||||
| @@ -586,7 +594,8 @@ AutoVacLauncherMain(int argc, char *argv[]) | |||||||
| 	 */ | 	 */ | ||||||
| 	rebuild_database_list(InvalidOid); | 	rebuild_database_list(InvalidOid); | ||||||
|  |  | ||||||
| 	for (;;) | 	/* loop until shutdown request */ | ||||||
|  | 	while (!got_SIGTERM) | ||||||
| 	{ | 	{ | ||||||
| 		struct timeval nap; | 		struct timeval nap; | ||||||
| 		TimestampTz current_time = 0; | 		TimestampTz current_time = 0; | ||||||
| @@ -786,6 +795,7 @@ AutoVacLauncherMain(int argc, char *argv[]) | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	/* Normal exit from the autovac launcher is here */ | 	/* Normal exit from the autovac launcher is here */ | ||||||
|  | shutdown: | ||||||
| 	ereport(LOG, | 	ereport(LOG, | ||||||
| 			(errmsg("autovacuum launcher shutting down"))); | 			(errmsg("autovacuum launcher shutting down"))); | ||||||
| 	AutoVacuumShmem->av_launcherpid = 0; | 	AutoVacuumShmem->av_launcherpid = 0; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user