server: Add "reason" parameter to interface::Server::shutdown() which is printed and logged as the last thing before the server exits
This commit is contained in:
parent
0f6900d669
commit
0c98f5ab4a
@ -40,7 +40,7 @@ namespace interface
|
|||||||
{
|
{
|
||||||
virtual ~Server(){}
|
virtual ~Server(){}
|
||||||
|
|
||||||
virtual void shutdown(int exit_status = 0) = 0;
|
virtual void shutdown(int exit_status = 0, const ss_ &reason="") = 0;
|
||||||
|
|
||||||
virtual bool load_module(const ss_ &module_name, const ss_ &path) = 0;
|
virtual bool load_module(const ss_ &module_name, const ss_ &path) = 0;
|
||||||
virtual void unload_module(const ss_ &module_name) = 0;
|
virtual void unload_module(const ss_ &module_name) = 0;
|
||||||
|
@ -11,6 +11,7 @@
|
|||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <signal.h>
|
#include <signal.h>
|
||||||
#include <string.h> // strerror()
|
#include <string.h> // strerror()
|
||||||
|
#define MODULE "main"
|
||||||
|
|
||||||
server::Config g_server_config;
|
server::Config g_server_config;
|
||||||
|
|
||||||
@ -117,6 +118,7 @@ int main(int argc, char *argv[])
|
|||||||
|
|
||||||
// Main loop
|
// Main loop
|
||||||
int exit_status = 0;
|
int exit_status = 0;
|
||||||
|
ss_ shutdown_reason;
|
||||||
uint64_t next_tick_us = get_timeofday_us();
|
uint64_t next_tick_us = get_timeofday_us();
|
||||||
uint64_t t_per_tick = 1000 * 100;
|
uint64_t t_per_tick = 1000 * 100;
|
||||||
set_<int> attempt_bad_fds;
|
set_<int> attempt_bad_fds;
|
||||||
@ -214,10 +216,20 @@ int main(int argc, char *argv[])
|
|||||||
|
|
||||||
state->handle_events();
|
state->handle_events();
|
||||||
|
|
||||||
if(state->is_shutdown_requested(&exit_status))
|
if(state->is_shutdown_requested(&exit_status, &shutdown_reason))
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Destruct server state here
|
||||||
|
state.reset(nullptr);
|
||||||
|
|
||||||
|
if(shutdown_reason != ""){
|
||||||
|
if(exit_status != 0)
|
||||||
|
log_w(MODULE, "Shutdown: %s", cs(shutdown_reason));
|
||||||
|
else
|
||||||
|
log_v(MODULE, "Shutdown: %s", cs(shutdown_reason));
|
||||||
|
}
|
||||||
|
|
||||||
return exit_status;
|
return exit_status;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -107,6 +107,7 @@ struct CState: public State, public interface::Server
|
|||||||
|
|
||||||
bool m_shutdown_requested = false;
|
bool m_shutdown_requested = false;
|
||||||
int m_shutdown_exit_status = 0;
|
int m_shutdown_exit_status = 0;
|
||||||
|
ss_ m_shutdown_reason;
|
||||||
|
|
||||||
up_<rccpp::Compiler> m_compiler;
|
up_<rccpp::Compiler> m_compiler;
|
||||||
ss_ m_modules_path;
|
ss_ m_modules_path;
|
||||||
@ -150,21 +151,27 @@ struct CState: public State, public interface::Server
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void shutdown(int exit_status)
|
void shutdown(int exit_status, const ss_ &reason)
|
||||||
{
|
{
|
||||||
if(m_shutdown_requested && exit_status == 0){
|
if(m_shutdown_requested && exit_status == 0){
|
||||||
// Only reset these values for exit values indicating failure
|
// Only reset these values for exit values indicating failure
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
log_i(MODULE, "Server shutdown requested; exit_status=%i", exit_status);
|
log_i(MODULE, "Server shutdown requested; exit_status=%i, reason=\"%s\"",
|
||||||
|
exit_status, cs(reason));
|
||||||
m_shutdown_requested = true;
|
m_shutdown_requested = true;
|
||||||
m_shutdown_exit_status = exit_status;
|
m_shutdown_exit_status = exit_status;
|
||||||
|
m_shutdown_reason = reason;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool is_shutdown_requested(int *exit_status = nullptr)
|
bool is_shutdown_requested(int *exit_status = nullptr, ss_ *reason = nullptr)
|
||||||
{
|
{
|
||||||
if(m_shutdown_requested && exit_status)
|
if(m_shutdown_requested){
|
||||||
*exit_status = m_shutdown_exit_status;
|
if(exit_status)
|
||||||
|
*exit_status = m_shutdown_exit_status;
|
||||||
|
if(reason)
|
||||||
|
*reason = m_shutdown_reason;
|
||||||
|
}
|
||||||
return m_shutdown_requested;
|
return m_shutdown_requested;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -24,8 +24,9 @@ namespace server
|
|||||||
struct State
|
struct State
|
||||||
{
|
{
|
||||||
virtual ~State(){}
|
virtual ~State(){}
|
||||||
virtual void shutdown(int exit_status = 0) = 0;
|
virtual void shutdown(int exit_status = 0, const ss_ &reason="") = 0;
|
||||||
virtual bool is_shutdown_requested(int *exit_status = nullptr) = 0;
|
virtual bool is_shutdown_requested(int *exit_status = nullptr,
|
||||||
|
ss_ *reason = nullptr) = 0;
|
||||||
virtual bool load_module(const ss_ &module_name, const ss_ &path) = 0;
|
virtual bool load_module(const ss_ &module_name, const ss_ &path) = 0;
|
||||||
virtual void load_modules(const ss_ &path) = 0;
|
virtual void load_modules(const ss_ &path) = 0;
|
||||||
virtual interface::Module* get_module(const ss_ &module_name) = 0;
|
virtual interface::Module* get_module(const ss_ &module_name) = 0;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user