diff options
| author | Peter Eisentraut <peter_e@gmx.net> | 2001-08-30 19:02:42 +0000 | 
|---|---|---|
| committer | Peter Eisentraut <peter_e@gmx.net> | 2001-08-30 19:02:42 +0000 | 
| commit | 68e53600186d3079f5ef108bcda21f75891ce127 (patch) | |
| tree | 26f3ae08550c9ae446a04c45fe803ae7382586c6 /src | |
| parent | 11193c8a200f54c766474340f723bb3a391e77f5 (diff) | |
Convert some fprintf's to elog's.
Diffstat (limited to 'src')
| -rw-r--r-- | src/backend/postmaster/postmaster.c | 195 | 
1 files changed, 115 insertions, 80 deletions
| diff --git a/src/backend/postmaster/postmaster.c b/src/backend/postmaster/postmaster.c index 1a6ebec5daf..7a588b1fc3c 100644 --- a/src/backend/postmaster/postmaster.c +++ b/src/backend/postmaster/postmaster.c @@ -37,7 +37,7 @@   *   *   * IDENTIFICATION - *	  $Header: /cvsroot/pgsql/src/backend/postmaster/postmaster.c,v 1.236 2001/08/17 02:59:19 momjian Exp $ + *	  $Header: /cvsroot/pgsql/src/backend/postmaster/postmaster.c,v 1.237 2001/08/30 19:02:42 petere Exp $   *   * NOTES   * @@ -152,8 +152,6 @@ static char *progname = (char *) NULL;  static char **real_argv;  static int	real_argc; -static time_t tnow; -  /* flag to indicate that SIGHUP arrived during server loop */  static volatile bool got_SIGHUP = false; @@ -241,7 +239,8 @@ static int	BackendStartup(Port *port);  static int	ProcessStartupPacket(Port *port, bool SSLdone);  static void	processCancelRequest(Port *port, void *pkt);  static int	initMasks(fd_set *rmask, fd_set *wmask); -static char *canAcceptConnections(void); +enum CAC_state { CAC_OK, CAC_STARTUP, CAC_SHUTDOWN, CAC_RECOVERY, CAC_TOOMANY }; +static enum CAC_state canAcceptConnections(void);  static long PostmasterRandom(void);  static void RandomSalt(char *cryptSalt, char *md5Salt);  static void SignalChildren(int signal); @@ -860,7 +859,7 @@ ServerLoop(void)  			PG_SETMASK(&BlockSig);  			if (errno == EINTR || errno == EWOULDBLOCK)  				continue; -			postmaster_error("ServerLoop: select failed: %s", strerror(errno)); +			elog(DEBUG, "ServerLoop: select failed: %s", strerror(errno));  			return STATUS_ERROR;  		} @@ -977,12 +976,15 @@ initMasks(fd_set *rmask, fd_set *wmask)   *   * Returns STATUS_OK or STATUS_ERROR, or might call elog(FATAL) and   * not return at all. + * + * (Note that elog(FATAL) stuff is sent to the client, so only use it + * if that's what you want.)   */  static int  ProcessStartupPacket(Port *port, bool SSLdone)  {  	StartupPacket *packet; -	char	   *rejectMsg; +	enum CAC_state cac;  	int32		len;  	void	   *buf; @@ -1025,8 +1027,8 @@ ProcessStartupPacket(Port *port, bool SSLdone)  #endif  		if (send(port->sock, &SSLok, 1, 0) != 1)  		{ -			postmaster_error("failed to send SSL negotiation response: %s", -							 strerror(errno)); +			elog(DEBUG, "failed to send SSL negotiation response: %s", +				 strerror(errno));  			return STATUS_ERROR; /* close the connection */  		} @@ -1037,8 +1039,8 @@ ProcessStartupPacket(Port *port, bool SSLdone)  				!SSL_set_fd(port->ssl, port->sock) ||  				SSL_accept(port->ssl) <= 0)  			{ -				postmaster_error("failed to initialize SSL connection: %s, errno: %d (%s)", -								 ERR_reason_error_string(ERR_get_error()), errno, strerror(errno)); +				elog(DEBUG, "failed to initialize SSL connection: %s (%s)", +					 ERR_reason_error_string(ERR_get_error()), strerror(errno));  				return STATUS_ERROR;  			}  		} @@ -1092,10 +1094,26 @@ ProcessStartupPacket(Port *port, bool SSLdone)  	 * so now instead of wasting cycles on an authentication exchange.  	 * (This also allows a pg_ping utility to be written.)  	 */ -	rejectMsg = canAcceptConnections(); +	cac = canAcceptConnections(); -	if (rejectMsg != NULL) -		elog(FATAL, "%s", rejectMsg); +	switch (cac) +	{ +		case CAC_STARTUP: +			elog(FATAL, "The database system is starting up"); +			break; +		case CAC_SHUTDOWN: +			elog(FATAL, "The database system is shutting down"); +			break; +		case CAC_RECOVERY: +			elog(FATAL, "The database system is in recovery mode"); +			break; +		case CAC_TOOMANY: +			elog(FATAL, "Sorry, too many clients already"); +			break; +		case CAC_OK: +		default: +			; +	}  	return STATUS_OK;  } @@ -1121,7 +1139,7 @@ processCancelRequest(Port *port, void *pkt)  	if (backendPID == CheckPointPID)  	{  		if (DebugLvl) -			postmaster_error("processCancelRequest: CheckPointPID in cancel request for process %d", backendPID); +			elog(DEBUG, "processCancelRequest: CheckPointPID in cancel request for process %d", backendPID);  		return;  	} @@ -1158,20 +1176,17 @@ processCancelRequest(Port *port, void *pkt)  /*   * canAcceptConnections --- check to see if database state allows connections. - * - * If we are open for business, return NULL, otherwise return an error message - * string suitable for rejecting a connection request.   */ -static char * +static enum CAC_state  canAcceptConnections(void)  {  	/* Can't start backends when in startup/shutdown/recovery state. */  	if (Shutdown > NoShutdown) -		return "The Data Base System is shutting down"; +		return CAC_SHUTDOWN;  	if (StartupPID) -		return "The Data Base System is starting up"; +		return CAC_STARTUP;  	if (FatalError) -		return "The Data Base System is in recovery mode"; +		return CAC_RECOVERY;  	/*  	 * Don't start too many children.  	 * @@ -1182,9 +1197,9 @@ canAcceptConnections(void)  	 * to join the shared-inval backend array.  	 */  	if (CountChildren() >= 2 * MaxBackends) -		return "Sorry, too many clients already"; +		return CAC_TOOMANY; -	return NULL; +	return CAC_OK;  } @@ -1198,7 +1213,7 @@ ConnCreate(int serverFd)  	if (!(port = (Port *) calloc(1, sizeof(Port))))  	{ -		postmaster_error("ConnCreate: malloc failed"); +		elog(DEBUG, "ConnCreate: malloc failed");  		SignalChildren(SIGQUIT);  		ExitPostmaster(1);  	} @@ -1343,9 +1358,7 @@ pmdie(SIGNAL_ARGS)  				return;  			}  			Shutdown = SmartShutdown; -			tnow = time(NULL); -			fprintf(stderr, gettext("Smart Shutdown request at %s"), ctime(&tnow)); -			fflush(stderr); +			elog(DEBUG, "smart shutdown request");  			if (DLGetHead(BackendList)) /* let reaper() handle this */  			{  				errno = save_errno; @@ -1363,8 +1376,8 @@ pmdie(SIGNAL_ARGS)  			}  			if (ShutdownPID > 0)  			{ -				postmaster_error("Shutdown process %d already running", -								 ShutdownPID); +				elog(REALLYFATAL, "shutdown process %d already running", +					 ShutdownPID);  				abort();  			} @@ -1385,16 +1398,13 @@ pmdie(SIGNAL_ARGS)  				errno = save_errno;  				return;  			} -			tnow = time(NULL); -			fprintf(stderr, gettext("Fast Shutdown request at %s"), ctime(&tnow)); -			fflush(stderr); +			elog(DEBUG, "fast shutdown request");  			if (DLGetHead(BackendList)) /* let reaper() handle this */  			{  				Shutdown = FastShutdown;  				if (!FatalError)  				{ -					fprintf(stderr, gettext("Aborting any active transaction...\n")); -					fflush(stderr); +					elog(DEBUG, "aborting any active transactions");  					SignalChildren(SIGTERM);  				}  				errno = save_errno; @@ -1419,8 +1429,8 @@ pmdie(SIGNAL_ARGS)  			}  			if (ShutdownPID > 0)  			{ -				postmaster_error("Shutdown process %d already running", -								 ShutdownPID); +				elog(REALLYFATAL, "shutdown process %d already running", +					 ShutdownPID);  				abort();  			} @@ -1436,9 +1446,7 @@ pmdie(SIGNAL_ARGS)  			 * abort all children with SIGQUIT and exit without attempt to  			 * properly shutdown data base system.  			 */ -			tnow = time(NULL); -			fprintf(stderr, gettext("Immediate Shutdown request at %s"), ctime(&tnow)); -			fflush(stderr); +			elog(DEBUG, "immediate shutdown request");  			if (ShutdownPID > 0)  				kill(ShutdownPID, SIGQUIT);  			if (StartupPID > 0) @@ -1472,7 +1480,7 @@ reaper(SIGNAL_ARGS)  	pqsignal(SIGCHLD, reaper);  	if (DebugLvl) -		postmaster_error("reaping dead processes"); +		elog(DEBUG, "reaping dead processes");  #ifdef HAVE_WAITPID  	while ((pid = waitpid(-1, &status, WNOHANG)) > 0)  	{ @@ -1488,37 +1496,56 @@ reaper(SIGNAL_ARGS)  		 */  		if (pgstat_ispgstat(pid))  		{ -			fprintf(stderr, "%s: Performance collector exited with status %d\n", -					progname, exitstatus); +			if (WIFEXITED(exitstatus)) +				elog(DEBUG, "statistics collector exited with status %d", +					 WEXITSTATUS(exitstatus)); +			else if (WIFSIGNALED(exitstatus)) +				elog(DEBUG, "statistics collector was terminated by signal %d", +					 WTERMSIG(exitstatus));  			pgstat_start(real_argc, real_argv);  			continue;  		}  		if (ShutdownPID > 0 && pid == ShutdownPID)  		{ -			if (exitstatus != 0) +			if (WIFEXITED(exitstatus) && WEXITSTATUS(exitstatus) != 0) +			{ +				elog(DEBUG, "shutdown process %d exited with status %d", +					 pid, WEXITSTATUS(exitstatus)); +				ExitPostmaster(1); +			} +			if (WIFSIGNALED(exitstatus))  			{ -				postmaster_error("Shutdown proc %d exited with status %d", pid, exitstatus); +				elog(DEBUG, "shutdown process %d was terminated by signal %d", +					 pid, WTERMSIG(exitstatus));  				ExitPostmaster(1);  			}  			ExitPostmaster(0);  		} +  		if (StartupPID > 0 && pid == StartupPID)  		{ -			if (exitstatus != 0) +			if (WIFEXITED(exitstatus) && WEXITSTATUS(exitstatus) != 0)  			{ -				postmaster_error("Startup proc %d exited with status %d - abort", -								 pid, exitstatus); +				elog(DEBUG, "startup process %d exited with status %d; aborting startup", +					 pid, WEXITSTATUS(exitstatus));  				ExitPostmaster(1);  			} +			if (WIFSIGNALED(exitstatus)) +			{ +				elog(DEBUG, "shutdown process %d was terminated by signal %d; aborting startup", +					 pid, WTERMSIG(exitstatus)); +				ExitPostmaster(1); +			} +  			StartupPID = 0;  			FatalError = false; /* done with recovery */  			if (Shutdown > NoShutdown)  			{  				if (ShutdownPID > 0)  				{ -					postmaster_error("Shutdown process %d already running", -									 ShutdownPID); +					elog(STOP, "startup process %d died while shutdown process %d already running", +						 pid, ShutdownPID);  					abort();  				}  				ShutdownPID = ShutdownDataBase(); @@ -1553,11 +1580,7 @@ reaper(SIGNAL_ARGS)  			errno = save_errno;  			return;  		} -		tnow = time(NULL); -		fprintf(stderr, gettext("Server processes were terminated at %s" -				"Reinitializing shared memory and semaphores\n"), -				ctime(&tnow)); -		fflush(stderr); +		elog(DEBUG, "all server processes terminated; reinitializing shared memory and semaphores");  		shmem_exit(0);  		reset_shared(PostPortNumber); @@ -1601,8 +1624,8 @@ CleanupProc(int pid,  	Backend    *bp;  	if (DebugLvl) -		postmaster_error("CleanupProc: pid %d exited with status %d", -						 pid, exitstatus); +		elog(DEBUG, "CleanupProc: pid %d exited with status %d", +			 pid, exitstatus);  	/*  	 * If a backend dies in an ugly way (i.e. exit status not 0) then we @@ -1642,14 +1665,18 @@ CleanupProc(int pid,  		return;  	} +	/* below here we're dealing with a non-normal exit */ + +	/* Make log entry unless we did so already */  	if (!FatalError)  	{ -		/* Make log entry unless we did so already */ -		tnow = time(NULL); -		fprintf(stderr, gettext("Server process (pid %d) exited with status %d at %s" -								"Terminating any active server processes...\n"), -				pid, exitstatus, ctime(&tnow)); -		fflush(stderr); +		if (WIFEXITED(exitstatus)) +			elog(DEBUG, "server process (pid %d) exited with status %d", +				 pid, WEXITSTATUS(exitstatus)); +		else if (WIFSIGNALED(exitstatus)) +			elog(DEBUG, "server process (pid %d) was terminated by signal %d", +				 pid, WTERMSIG(exitstatus)); +		elog(DEBUG, "terminating any other active server processes");  	}  	curr = DLGetHead(BackendList); @@ -1671,9 +1698,9 @@ CleanupProc(int pid,  			if (!FatalError)  			{  				if (DebugLvl) -					postmaster_error("CleanupProc: sending %s to process %d", -									 (SendStop ? "SIGSTOP" : "SIGQUIT"), -									 bp->pid); +					elog(DEBUG, "CleanupProc: sending %s to process %d", +						 (SendStop ? "SIGSTOP" : "SIGQUIT"), +						 bp->pid);  				kill(bp->pid, (SendStop ? SIGSTOP : SIGQUIT));  			}  		} @@ -1776,8 +1803,7 @@ BackendStartup(Port *port)  	bn = (Backend *) malloc(sizeof(Backend));  	if (!bn)  	{ -		fprintf(stderr, gettext("%s: BackendStartup: malloc failed\n"), -				progname); +		elog(DEBUG, "out of memory; connection startup aborted");  		return STATUS_ERROR;  	} @@ -1796,8 +1822,7 @@ BackendStartup(Port *port)  		status = DoBackend(port);  		if (status != 0)  		{ -			fprintf(stderr, gettext("%s child[%d]: BackendStartup: backend startup failed\n"), -					progname, (int) getpid()); +			elog(DEBUG, "connection startup failed");  			proc_exit(status);  		}  		else @@ -1812,16 +1837,15 @@ BackendStartup(Port *port)  		/* Specific beos backend startup actions */  		beos_backend_startup_failed();  #endif -		fprintf(stderr, gettext("%s: BackendStartup: fork failed: %s\n"), -				progname, strerror(errno)); +		elog(DEBUG, "connection startup failed (fork failure): %s", +			 strerror(errno));  		return STATUS_ERROR;  	}  	/* in parent, normal */  	if (DebugLvl >= 1) -		fprintf(stderr, gettext("%s: BackendStartup: pid=%d user=%s db=%s socket=%d\n"), -				progname, pid, port->user, port->database, -				port->sock); +		elog(DEBUG, "BackendStartup: pid=%d user=%s db=%s socket=%d\n", +			 pid, port->user, port->database, port->sock);  	/*  	 * Everything's been successful, it's safe to add this backend to our @@ -2267,11 +2291,22 @@ SSDataBase(int xlop)  		beos_backend_startup_failed();  #endif -		fprintf(stderr, "%s Data Base: fork failed: %s\n", -				((xlop == BS_XLOG_STARTUP) ? "Startup" : -				 ((xlop == BS_XLOG_CHECKPOINT) ? "CheckPoint" : -				  "Shutdown")), -				strerror(errno)); +		switch(xlop) +		{ +			case BS_XLOG_STARTUP: +				elog(DEBUG, "could not launch startup process (fork failure): %s", +					 strerror(errno)); +				break; +			case BS_XLOG_CHECKPOINT: +				elog(DEBUG, "could not launch checkpoint process (fork failure): %s", +					 strerror(errno)); +				break; +			case BS_XLOG_SHUTDOWN: +			default: +				elog(DEBUG, "could not launch shutdown process (fork failure): %s", +					 strerror(errno)); +				break; +		}  		/*  		 * fork failure is fatal during startup/shutdown, but there's no @@ -2291,7 +2326,7 @@ SSDataBase(int xlop)  	{  		if (!(bn = (Backend *) calloc(1, sizeof(Backend))))  		{ -			postmaster_error("CheckPointDataBase: malloc failed"); +			elog(DEBUG, "CheckPointDataBase: malloc failed");  			ExitPostmaster(1);  		} | 
