$Revision$ $Date$ The Server Showdown The server shutdown can be triggered by sending a signal to the server. The server will behave differently upon receiving various types of signals, here is a brief summary: SIGINT, SIGPIPE, SIGTERM, SIGCHLD will terminate the server. SIGUSR1 will print statistics and let the server continue. SIGHUP, SIGUSR2 will be ignored. There is only one common signal handler for all signals - function sig_usr in file main.c. In normal mode of operation (dont_fork variable is not set), the main server is not processing any requests, it calls pause function and will be waiting for signals only. What happens when a signal arrives is shown in the previous paragraph. When in normal mode (dont_fork is not set), the signal handler of the main process will only store number of the signal received. All the processing logic will be executed by the main process outside the signal handler (function handle_sigs) The function will be called immediately after the signal handler finish. The main process usually does some cleanup and running such things outside the signal handler is much more safe than doing it from the handler itself. Children only print statistics and exit or ignore the signal completely, that is quite safe and can be done directly from the signal handler of children. When dont_fork is set, all the cleanup will be done directly from the signal handler, because there is only one process - the main process. This is not so safe as the previous case, but this mode should be used for debugging only and such shortcoming doesn't harm in that case. Upon receipt of SIGINT, SIGPIPE or SIGTERM destroy_modules will be called. Each module may register so-called destroy function if it needs to do some cleanup when the server is terminating (flush of cache to disk for example). destroy_modules will call destroy function of all loaded modules. If you need to terminate the server and all of its children, the best way how to do it is to send SIGTERM to the main process, the main process will in turn send the same signal to its children. The main process and its children are in the same process group. Therefore the main process can kill all its children simply by sending a signal to pid 0, sending to pid 0 will send the signal to all processes in the same process group as the sending process. This is how the main process will terminate all children when it is going to shut down. If one child exited during normal operation, the whole server will be shut down. This is better than let the server continue - a dead child might hold a lock and that could block the whole server, such situation cannot be avoided easily. Instead of that it is better to shutdown the whole server and let it restart.