8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-22 20:43:02 +01:00

Added shutdown handler for server (#8165)

Co-authored-by: Alexander Zhdanov <alexander.zhdanov@red-soft.ru>
This commit is contained in:
Alexander 2024-07-08 10:42:56 +03:00 committed by GitHub
parent 262af1d2fc
commit 6e7596f78e
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -115,6 +115,7 @@ const char* TEMP_DIR = "/tmp";
static void set_signal(int, void (*)(int)); static void set_signal(int, void (*)(int));
static void signal_handler(int); static void signal_handler(int);
static void shutdown_handler(int);
static TEXT protocol[128]; static TEXT protocol[128];
static int INET_SERVER_start = 0; static int INET_SERVER_start = 0;
@ -314,6 +315,13 @@ int CLIB_ROUTINE main( int argc, char** argv)
// activate paths set with -e family of switches // activate paths set with -e family of switches
ISC_set_prefix(0, 0); ISC_set_prefix(0, 0);
// set shutdown signals handler for listener
if (standaloneClassic)
{
set_signal(SIGTERM, shutdown_handler);
set_signal(SIGINT, shutdown_handler);
}
// ignore some signals // ignore some signals
set_signal(SIGPIPE, signal_handler); set_signal(SIGPIPE, signal_handler);
set_signal(SIGUSR1, signal_handler); set_signal(SIGUSR1, signal_handler);
@ -507,6 +515,13 @@ int CLIB_ROUTINE main( int argc, char** argv)
} }
} }
// set default handlers for child processes
if (standaloneClassic)
{
signal(SIGTERM, SIG_DFL);
signal(SIGINT, SIG_DFL);
}
if (classic) if (classic)
{ {
port = INET_server(channel); port = INET_server(channel);
@ -631,6 +646,23 @@ static void signal_handler(int)
++INET_SERVER_start; ++INET_SERVER_start;
} }
static void shutdown_handler(int)
{
/**************************************
*
* s h u t d o w n _ h a n d l e r
*
**************************************
*
* Functional description
* Forward sigterm signal to all child processes.
*
**************************************/
kill(-1 * getpid(), SIGTERM);
exit(FINI_OK);
}
#ifdef FB_RAISE_LIMITS #ifdef FB_RAISE_LIMITS
static void raiseLimit(int resource) static void raiseLimit(int resource)