2003-05-21 21:28:21 +08:00
|
|
|
|
|
|
|
#include <ngx_config.h>
|
|
|
|
#include <ngx_core.h>
|
|
|
|
|
|
|
|
|
|
|
|
int ngx_max_sockets;
|
|
|
|
int ngx_inherited_nonblocking;
|
|
|
|
|
|
|
|
|
2003-07-04 00:30:22 +08:00
|
|
|
void ngx_restart_signal_handler(int signo);
|
|
|
|
void ngx_rotate_signal_handler(int signo);
|
|
|
|
|
|
|
|
|
2003-05-21 21:28:21 +08:00
|
|
|
int ngx_posix_init(ngx_log_t *log)
|
|
|
|
{
|
2003-11-20 00:26:41 +08:00
|
|
|
struct rlimit rlmt;
|
|
|
|
struct sigaction sa;
|
2003-05-21 21:28:21 +08:00
|
|
|
|
|
|
|
ngx_memzero(&sa, sizeof(struct sigaction));
|
|
|
|
sa.sa_handler = SIG_IGN;
|
|
|
|
sigemptyset(&sa.sa_mask);
|
|
|
|
if (sigaction(SIGPIPE, &sa, NULL) == -1) {
|
|
|
|
ngx_log_error(NGX_LOG_EMERG, log, ngx_errno,
|
|
|
|
"sigaction(SIGPIPE, SIG_IGN) failed");
|
|
|
|
return NGX_ERROR;
|
|
|
|
}
|
|
|
|
|
2003-11-20 00:26:41 +08:00
|
|
|
ngx_memzero(&sa, sizeof(struct sigaction));
|
|
|
|
sa.sa_handler = ngx_sigchld_handler;
|
|
|
|
sigemptyset(&sa.sa_mask);
|
|
|
|
if (sigaction(SIGCHLD, &sa, NULL) == -1) {
|
|
|
|
ngx_log_error(NGX_LOG_EMERG, log, ngx_errno,
|
|
|
|
"sigaction(SIGCHLD) failed");
|
|
|
|
return NGX_ERROR;
|
|
|
|
}
|
|
|
|
|
2003-07-04 00:30:22 +08:00
|
|
|
sa.sa_handler = ngx_restart_signal_handler;
|
2003-07-11 12:50:59 +08:00
|
|
|
if (sigaction(ngx_signal_value(NGX_RESTART_SIGNAL), &sa, NULL) == -1) {
|
2003-07-04 00:30:22 +08:00
|
|
|
ngx_log_error(NGX_LOG_EMERG, log, ngx_errno,
|
2003-07-11 12:50:59 +08:00
|
|
|
"sigaction(SIG" ngx_value(NGX_RESTART_SIGNAL) ") failed");
|
2003-07-04 00:30:22 +08:00
|
|
|
return NGX_ERROR;
|
|
|
|
}
|
|
|
|
|
|
|
|
sa.sa_handler = ngx_rotate_signal_handler;
|
2003-07-11 12:50:59 +08:00
|
|
|
if (sigaction(ngx_signal_value(NGX_ROTATE_SIGNAL), &sa, NULL) == -1) {
|
2003-07-04 00:30:22 +08:00
|
|
|
ngx_log_error(NGX_LOG_EMERG, log, ngx_errno,
|
2003-07-11 12:50:59 +08:00
|
|
|
"sigaction(SIG" ngx_value(NGX_ROTATE_SIGNAL) ") failed");
|
2003-07-04 00:30:22 +08:00
|
|
|
return NGX_ERROR;
|
|
|
|
}
|
|
|
|
|
2003-05-21 21:28:21 +08:00
|
|
|
|
|
|
|
if (getrlimit(RLIMIT_NOFILE, &rlmt) == -1) {
|
|
|
|
ngx_log_error(NGX_LOG_ALERT, log, errno,
|
|
|
|
"getrlimit(RLIMIT_NOFILE) failed)");
|
|
|
|
return NGX_ERROR;
|
|
|
|
}
|
|
|
|
|
|
|
|
ngx_log_error(NGX_LOG_INFO, log, 0,
|
2003-11-14 00:16:33 +08:00
|
|
|
"getrlimit(RLIMIT_NOFILE): " RLIM_FMT ":" RLIM_FMT,
|
2003-05-21 21:28:21 +08:00
|
|
|
rlmt.rlim_cur, rlmt.rlim_max);
|
|
|
|
|
|
|
|
ngx_max_sockets = rlmt.rlim_cur;
|
|
|
|
|
|
|
|
#if (HAVE_INHERITED_NONBLOCK)
|
|
|
|
ngx_inherited_nonblocking = 1;
|
|
|
|
#else
|
|
|
|
ngx_inherited_nonblocking = 0;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
return NGX_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2003-07-04 00:30:22 +08:00
|
|
|
void ngx_restart_signal_handler(int signo)
|
|
|
|
{
|
|
|
|
restart = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void ngx_rotate_signal_handler(int signo)
|
|
|
|
{
|
|
|
|
rotate = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2003-05-21 21:28:21 +08:00
|
|
|
int ngx_posix_post_conf_init(ngx_log_t *log)
|
|
|
|
{
|
|
|
|
ngx_fd_t pp[2];
|
|
|
|
|
|
|
|
if (pipe(pp) == -1) {
|
|
|
|
ngx_log_error(NGX_LOG_EMERG, log, ngx_errno, "pipe() failed");
|
|
|
|
return NGX_ERROR;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (dup2(pp[1], STDERR_FILENO) == -1) {
|
|
|
|
ngx_log_error(NGX_LOG_EMERG, log, errno, "dup2(STDERR) failed");
|
|
|
|
return NGX_ERROR;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (pp[1] > STDERR_FILENO) {
|
|
|
|
if (close(pp[1]) == -1) {
|
|
|
|
ngx_log_error(NGX_LOG_EMERG, log, errno, "close() failed");
|
|
|
|
return NGX_ERROR;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return NGX_OK;
|
|
|
|
}
|