mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Unify SIGHUP handling between normal and walsender backends.
Because walsender and normal backends share the same main loop it's problematic to have two different flag variables, set in signal handlers, indicating a pending configuration reload. Only certain walsender commands reach code paths checking for the variable (START_[LOGICAL_]REPLICATION, CREATE_REPLICATION_SLOT ... LOGICAL, notably not base backups). This is a bug present since the introduction of walsender, but has gotten worse in releases since then which allow walsender to do more. A later patch, not slated for v10, will similarly unify SIGHUP handling in other types of processes as well. Author: Petr Jelinek, Andres Freund Reviewed-By: Michael Paquier Discussion: https://postgr.es/m/20170423235941.qosiuoyqprq4nu7v@alap3.anarazel.de Backpatch: 9.2-, bug is present since 9.0
This commit is contained in:
		| @@ -122,13 +122,6 @@ char	   *stack_base_ptr = NULL; | ||||
| char	   *register_stack_base_ptr = NULL; | ||||
| #endif | ||||
|  | ||||
| /* | ||||
|  * Flag to mark SIGHUP. Whenever the main loop comes around it | ||||
|  * will reread the configuration file. (Better than doing the | ||||
|  * reading in the signal handler, ey?) | ||||
|  */ | ||||
| static volatile sig_atomic_t got_SIGHUP = false; | ||||
|  | ||||
| /* | ||||
|  * Flag to keep track of whether we have started a transaction. | ||||
|  * For extended query protocol this has to be remembered across messages. | ||||
| @@ -187,7 +180,6 @@ static bool IsTransactionExitStmt(Node *parsetree); | ||||
| static bool IsTransactionExitStmtList(List *pstmts); | ||||
| static bool IsTransactionStmtList(List *pstmts); | ||||
| static void drop_unnamed_stmt(void); | ||||
| static void SigHupHandler(SIGNAL_ARGS); | ||||
| static void log_disconnections(int code, Datum arg); | ||||
|  | ||||
|  | ||||
| @@ -2684,13 +2676,19 @@ FloatExceptionHandler(SIGNAL_ARGS) | ||||
| 					   "invalid operation, such as division by zero."))); | ||||
| } | ||||
|  | ||||
| /* SIGHUP: set flag to re-read config file at next convenient time */ | ||||
| static void | ||||
| SigHupHandler(SIGNAL_ARGS) | ||||
| /* | ||||
|  * SIGHUP: set flag to re-read config file at next convenient time. | ||||
|  * | ||||
|  * Sets the ConfigReloadPending flag, which should be checked at convenient | ||||
|  * places inside main loops. (Better than doing the reading in the signal | ||||
|  * handler, ey?) | ||||
|  */ | ||||
| void | ||||
| PostgresSigHupHandler(SIGNAL_ARGS) | ||||
| { | ||||
| 	int			save_errno = errno; | ||||
|  | ||||
| 	got_SIGHUP = true; | ||||
| 	ConfigReloadPending = true; | ||||
| 	SetLatch(MyLatch); | ||||
|  | ||||
| 	errno = save_errno; | ||||
| @@ -3632,8 +3630,8 @@ PostgresMain(int argc, char *argv[], | ||||
| 		WalSndSignals(); | ||||
| 	else | ||||
| 	{ | ||||
| 		pqsignal(SIGHUP, SigHupHandler);		/* set flag to read config | ||||
| 												 * file */ | ||||
| 		pqsignal(SIGHUP, PostgresSigHupHandler);		/* set flag to read config | ||||
| 														 * file */ | ||||
| 		pqsignal(SIGINT, StatementCancelHandler);		/* cancel current query */ | ||||
| 		pqsignal(SIGTERM, die); /* cancel current query and exit */ | ||||
|  | ||||
| @@ -4046,9 +4044,9 @@ PostgresMain(int argc, char *argv[], | ||||
| 		 * (6) check for any other interesting events that happened while we | ||||
| 		 * slept. | ||||
| 		 */ | ||||
| 		if (got_SIGHUP) | ||||
| 		if (ConfigReloadPending) | ||||
| 		{ | ||||
| 			got_SIGHUP = false; | ||||
| 			ConfigReloadPending = false; | ||||
| 			ProcessConfigFile(PGC_SIGHUP); | ||||
| 		} | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user