mirror of https://github.com/Icinga/icinga2.git
Use RequestShutdown with exitcode instead of Application::Exit
fixes #8436
This commit is contained in:
parent
2884e8318d
commit
9ed21563ff
|
@ -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 */
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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();
|
||||||
|
|
|
@ -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();
|
||||||
|
|
|
@ -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();
|
||||||
|
|
|
@ -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();
|
||||||
|
|
Loading…
Reference in New Issue