79e64b1233
*) Change: the "variables_hash_max_size" and "variables_hash_bucket_size" directives. *) Feature: the $body_bytes_sent variable can be used not only in the "log_format" directive. *) Feature: the $ssl_protocol and $ssl_cipher variables. *) Feature: the cache line size detection for widespread CPUs at start time. *) Feature: now the "accept_mutex" directive is supported using fcntl(2) on platforms different from i386, amd64, sparc64, and ppc. *) Feature: the "lock_file" directive and the --with-lock-path=PATH autoconfiguration directive. *) Bugfix: if the HTTPS protocol was used in the "proxy_pass" directive then the requests with the body was not transferred.
110 lines
2 KiB
C
110 lines
2 KiB
C
|
|
/*
|
|
* Copyright (C) Igor Sysoev
|
|
*/
|
|
|
|
|
|
#include <ngx_config.h>
|
|
#include <ngx_core.h>
|
|
#include <nginx.h>
|
|
|
|
|
|
ngx_int_t ngx_ncpu;
|
|
ngx_int_t ngx_max_sockets;
|
|
ngx_uint_t ngx_inherited_nonblocking;
|
|
ngx_uint_t ngx_tcp_nodelay_and_tcp_nopush;
|
|
|
|
|
|
struct rlimit rlmt;
|
|
|
|
|
|
ngx_os_io_t ngx_os_io = {
|
|
ngx_unix_recv,
|
|
ngx_readv_chain,
|
|
NULL,
|
|
ngx_writev_chain,
|
|
0
|
|
};
|
|
|
|
|
|
ngx_int_t
|
|
ngx_os_init(ngx_log_t *log)
|
|
{
|
|
#if (NGX_HAVE_OS_SPECIFIC_INIT)
|
|
if (ngx_os_specific_init(log) != NGX_OK) {
|
|
return NGX_ERROR;
|
|
}
|
|
#endif
|
|
|
|
ngx_init_setproctitle(log);
|
|
|
|
ngx_pagesize = getpagesize();
|
|
ngx_cacheline_size = NGX_CPU_CACHE_LINE;
|
|
|
|
if (ngx_ncpu == 0) {
|
|
ngx_ncpu = 1;
|
|
}
|
|
|
|
ngx_cpuinfo();
|
|
|
|
if (getrlimit(RLIMIT_NOFILE, &rlmt) == -1) {
|
|
ngx_log_error(NGX_LOG_ALERT, log, errno,
|
|
"getrlimit(RLIMIT_NOFILE) failed)");
|
|
return NGX_ERROR;
|
|
}
|
|
|
|
ngx_max_sockets = (ngx_int_t) rlmt.rlim_cur;
|
|
|
|
#if (NGX_HAVE_INHERITED_NONBLOCK)
|
|
ngx_inherited_nonblocking = 1;
|
|
#else
|
|
ngx_inherited_nonblocking = 0;
|
|
#endif
|
|
|
|
return NGX_OK;
|
|
}
|
|
|
|
|
|
void
|
|
ngx_os_status(ngx_log_t *log)
|
|
{
|
|
ngx_log_error(NGX_LOG_NOTICE, log, 0, NGINX_VER);
|
|
|
|
#ifdef NGX_COMPILER
|
|
ngx_log_error(NGX_LOG_NOTICE, log, 0, "built by " NGX_COMPILER);
|
|
#endif
|
|
|
|
#if (NGX_HAVE_OS_SPECIFIC_INIT)
|
|
ngx_os_specific_status(log);
|
|
#endif
|
|
|
|
ngx_log_error(NGX_LOG_NOTICE, log, 0,
|
|
"getrlimit(RLIMIT_NOFILE): %r:%r",
|
|
rlmt.rlim_cur, rlmt.rlim_max);
|
|
}
|
|
|
|
|
|
ngx_int_t
|
|
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;
|
|
}
|