Use RequestShutdown with exitcode instead of Application::Exit

fixes #8436
This commit is contained in:
Jean-Marcel Flach 2015-02-26 17:09:45 +01:00 committed by Gunnar Beutner
parent 2884e8318d
commit 9ed21563ff
7 changed files with 25 additions and 30 deletions

View File

@ -653,7 +653,7 @@ int main(int argc, char **argv)
}; };
StartServiceCtrlDispatcher(dispatchTable); StartServiceCtrlDispatcher(dispatchTable);
Application::Exit(1); Application::Exit(EXIT_FAILURE);
} }
#endif /* _WIN32 */ #endif /* _WIN32 */

View File

@ -54,6 +54,7 @@ static bool l_InExceptionHandler = false;
int Application::m_ArgC; int Application::m_ArgC;
char **Application::m_ArgV; char **Application::m_ArgV;
double Application::m_StartTime; double Application::m_StartTime;
int Application::m_ExitStatus = 0;
/** /**
* Constructor for the Application class. * Constructor for the Application class.
@ -110,7 +111,6 @@ void Application::Exit(int rc)
} }
UninitializeBase(); UninitializeBase();
#ifdef I2_DEBUG #ifdef I2_DEBUG
exit(rc); exit(rc);
#else /* I2_DEBUG */ #else /* I2_DEBUG */
@ -308,7 +308,11 @@ mainloop:
goto mainloop; goto mainloop;
} }
if (m_ExitStatus)
Log(LogInformation, "Application", "Shutting down Icinga after a fatal error.");
else
Log(LogInformation, "Application", "Shutting down Icinga..."); Log(LogInformation, "Application", "Shutting down Icinga...");
DynamicObject::StopObjects(); DynamicObject::StopObjects();
Application::GetInstance()->OnShutdown(); Application::GetInstance()->OnShutdown();
@ -355,8 +359,9 @@ pid_t Application::StartReloadProcess(void)
* Signals the application to shut down during the next * Signals the application to shut down during the next
* execution of the event loop. * execution of the event loop.
*/ */
void Application::RequestShutdown(void) void Application::RequestShutdown(int rc)
{ {
m_ExitStatus = rc > m_ExitStatus ? rc : m_ExitStatus;
m_ShuttingDown = true; m_ShuttingDown = true;
} }

View File

@ -69,7 +69,7 @@ public:
static void InstallExceptionHandlers(void); static void InstallExceptionHandlers(void);
static void RequestShutdown(void); static void RequestShutdown(int rc = 0);
static void RequestRestart(void); static void RequestRestart(void);
static void RequestReopenLogs(void); static void RequestReopenLogs(void);
@ -162,6 +162,7 @@ private:
static bool m_Debugging; /**< Whether debugging is enabled. */ static bool m_Debugging; /**< Whether debugging is enabled. */
static LogSeverity m_DebuggingSeverity; /**< Whether debugging severity is set. */ static LogSeverity m_DebuggingSeverity; /**< Whether debugging severity is set. */
static double m_StartTime; static double m_StartTime;
static int m_ExitStatus;
#ifndef _WIN32 #ifndef _WIN32
static void SigIntTermHandler(int signum); static void SigIntTermHandler(int signum);

View File

@ -93,14 +93,14 @@ static bool Daemonize(void)
if (ret == pid) { if (ret == pid) {
Log(LogCritical, "cli", "The daemon could not be started. See log output for details."); Log(LogCritical, "cli", "The daemon could not be started. See log output for details.");
Application::Exit(EXIT_FAILURE); _exit(EXIT_FAILURE);
} else if (ret == -1) { } else if (ret == -1) {
Log(LogCritical, "cli") Log(LogCritical, "cli")
<< "waitpid() failed with error code " << errno << ", \"" << Utility::FormatErrorNumber(errno) << "\""; << "waitpid() failed with error code " << errno << ", \"" << Utility::FormatErrorNumber(errno) << "\"";
Application::Exit(EXIT_FAILURE); _exit(EXIT_FAILURE);
} }
Application::Exit(0); _exit(EXIT_SUCCESS);
} }
Application::GetTP().Start(); Application::GetTP().Start();

View File

@ -225,7 +225,7 @@ void IdoMysqlConnection::Reconnect(void)
if (!row) { if (!row) {
Log(LogCritical, "IdoMysqlConnection", "Schema does not provide any valid version! Verify your schema installation."); Log(LogCritical, "IdoMysqlConnection", "Schema does not provide any valid version! Verify your schema installation.");
Application::Exit(EXIT_FAILURE); Application::RequestShutdown(EXIT_FAILURE);
} }
DiscardRows(result); DiscardRows(result);
@ -237,7 +237,7 @@ void IdoMysqlConnection::Reconnect(void)
<< "Schema version '" << version << "' does not match the required version '" << "Schema version '" << version << "' does not match the required version '"
<< SCHEMA_VERSION << "'! Please check the upgrade documentation."; << SCHEMA_VERSION << "'! Please check the upgrade documentation.";
Application::Exit(EXIT_FAILURE); Application::RequestShutdown(EXIT_FAILURE);
} }
String instanceName = GetInstanceName(); String instanceName = GetInstanceName();

View File

@ -225,7 +225,7 @@ void IdoPgsqlConnection::Reconnect(void)
if (!row) { if (!row) {
Log(LogCritical, "IdoPgsqlConnection", "Schema does not provide any valid version! Verify your schema installation."); Log(LogCritical, "IdoPgsqlConnection", "Schema does not provide any valid version! Verify your schema installation.");
Application::Exit(EXIT_FAILURE); Application::RequestShutdown(EXIT_FAILURE);
} }
String version = row->Get("version"); String version = row->Get("version");
@ -235,7 +235,7 @@ void IdoPgsqlConnection::Reconnect(void)
<< "Schema version '" << version << "' does not match the required version '" << "Schema version '" << version << "' does not match the required version '"
<< SCHEMA_VERSION << "'! Please check the upgrade documentation."; << SCHEMA_VERSION << "'! Please check the upgrade documentation.";
Application::Exit(EXIT_FAILURE); Application::RequestShutdown(EXIT_FAILURE);
} }
String instanceName = GetInstanceName(); String instanceName = GetInstanceName();

View File

@ -49,17 +49,13 @@ void ApiListener::OnConfigLoaded(void)
try { try {
cert = GetX509Certificate(GetCertPath()); cert = GetX509Certificate(GetCertPath());
} catch (const std::exception&) { } catch (const std::exception&) {
Log(LogCritical, "ApiListener") BOOST_THROW_EXCEPTION(ScriptError("Cannot get certificate from cert path: '" + GetCertPath() + "'.", GetDebugInfo()));
<< "Cannot get certificate from cert path: '" << GetCertPath() << "'.";
Application::Exit(EXIT_FAILURE);
} }
try { try {
SetIdentity(GetCertificateCN(cert)); SetIdentity(GetCertificateCN(cert));
} catch (const std::exception&) { } catch (const std::exception&) {
Log(LogCritical, "ApiListener") BOOST_THROW_EXCEPTION(ScriptError("Cannot get certificate common name from cert path: '" + GetCertPath() + "'.", GetDebugInfo()));
<< "Cannot get certificate common name from cert path: '" << GetCertPath() << "'.";
Application::Exit(EXIT_FAILURE);
} }
Log(LogInformation, "ApiListener") Log(LogInformation, "ApiListener")
@ -68,29 +64,22 @@ void ApiListener::OnConfigLoaded(void)
try { try {
m_SSLContext = MakeSSLContext(GetCertPath(), GetKeyPath(), GetCaPath()); m_SSLContext = MakeSSLContext(GetCertPath(), GetKeyPath(), GetCaPath());
} catch (const std::exception&) { } catch (const std::exception&) {
Log(LogCritical, "ApiListener") BOOST_THROW_EXCEPTION(ScriptError("Cannot make SSL context for cert path: '" + GetCertPath() + "' key path: '" + GetKeyPath() + "' ca path: '" + GetCaPath() + "'.", GetDebugInfo()));
<< "Cannot make SSL context for cert path: '" << GetCertPath() << "' key path: '" << GetKeyPath() << "' ca path: '" << GetCaPath() << "'.";
Application::Exit(EXIT_FAILURE);
} }
if (!GetCrlPath().IsEmpty()) { if (!GetCrlPath().IsEmpty()) {
try { try {
AddCRLToSSLContext(m_SSLContext, GetCrlPath()); AddCRLToSSLContext(m_SSLContext, GetCrlPath());
} catch (const std::exception&) { } catch (const std::exception&) {
Log(LogCritical, "ApiListener") BOOST_THROW_EXCEPTION(ScriptError("Cannot add certificate revocation list to SSL context for crl path: '" + GetCrlPath() + "'.", GetDebugInfo()));
<< "Cannot add certificate revocation list to SSL context for crl path: '" << GetCrlPath() << "'.";
Application::Exit(EXIT_FAILURE);
} }
} }
} }
void ApiListener::OnAllConfigLoaded(void) void ApiListener::OnAllConfigLoaded(void)
{ {
if (!Endpoint::GetByName(GetIdentity())) { if (!Endpoint::GetByName(GetIdentity()))
Log(LogCritical, "ApiListener") BOOST_THROW_EXCEPTION(ScriptError("Endpoint object for '" + GetIdentity() + "' is missing.", GetDebugInfo()));
<< "Endpoint object for '" << GetIdentity() << "' is missing.";
Application::Exit(EXIT_FAILURE);
}
} }
/** /**
@ -117,7 +106,7 @@ void ApiListener::Start(void)
if (!AddListener(GetBindHost(), GetBindPort())) { if (!AddListener(GetBindHost(), GetBindPort())) {
Log(LogCritical, "ApiListener") Log(LogCritical, "ApiListener")
<< "Cannot add listener on host '" << GetBindHost() << "' for port '" << GetBindPort() << "'."; << "Cannot add listener on host '" << GetBindHost() << "' for port '" << GetBindPort() << "'.";
Application::Exit(EXIT_FAILURE); Application::RequestShutdown(EXIT_FAILURE);
} }
m_Timer = new Timer(); m_Timer = new Timer();