定义在 src\core\ngx_log.c
ngx_log_t *
ngx_log_init(u_char *prefix, u_char *error_log)
{
u_char *p, *name;
size_t nlen, plen;
ngx_log.file = &ngx_log_file;
ngx_log.log_level = NGX_LOG_NOTICE;
if (error_log == NULL) {
error_log = (u_char *) NGX_ERROR_LOG_PATH;
}
name = error_log;
nlen = ngx_strlen(name);
if (nlen == 0) {
ngx_log_file.fd = ngx_stderr;
return &ngx_log;
}
p = NULL;
#if (NGX_WIN32)
if (name[1] != ':') {
#else
if (name[0] != '/') {
#endif
if (prefix) {
plen = ngx_strlen(prefix);
} else {
#ifdef NGX_PREFIX
prefix = (u_char *) NGX_PREFIX;
plen = ngx_strlen(prefix);
#else
plen = 0;
#endif
}
if (plen) {
name = malloc(plen + nlen + 2);
if (name == NULL) {
return NULL;
}
p = ngx_cpymem(name, prefix, plen);
if (!ngx_path_separator(*(p - 1))) {
*p++ = '/';
}
ngx_cpystrn(p, error_log, nlen + 1);
p = name;
}
}
ngx_log_file.fd = ngx_open_file(name, NGX_FILE_APPEND,
NGX_FILE_CREATE_OR_OPEN,
NGX_FILE_DEFAULT_ACCESS);
if (ngx_log_file.fd == NGX_INVALID_FILE) {
ngx_log_stderr(ngx_errno,
"[alert] could not open error log file: "
ngx_open_file_n " \"%s\" failed", name);
#if (NGX_WIN32)
ngx_event_log(ngx_errno,
"could not open error log file: "
ngx_open_file_n " \"%s\" failed", name);
#endif
ngx_log_file.fd = ngx_stderr;
}
if (p) {
ngx_free(p);
}
return &ngx_log;
}
ngx_log_init
函数是 Nginx 中用于初始化错误日志的核心函数参数解析
prefix
: 日志路径的前缀(通常是 Nginx 安装目录的路径)。如果日志路径是相对路径,则会基于此前缀构建完整路径。error_log
: 指定的日志文件路径。如果为NULL
,则使用默认路径NGX_ERROR_LOG_PATH
。
ngx_log_t *
ngx_log_init(u_char *prefix, u_char *error_log)
{
u_char *p, *name;
size_t nlen, plen;
ngx_log.file = &ngx_log_file;
ngx_log.log_level = NGX_LOG_NOTICE;
- 将全局日志对象
ngx_log
的文件指针指向ngx_log_file
。- 设置默认日志级别为
NGX_LOG_NOTICE
(通知级别)。
if (error_log == NULL) {
error_log = (u_char *) NGX_ERROR_LOG_PATH;
}
未指定
error_log 时
,则使用默认路径NGX_ERROR_LOG_PATH
此时
error_log=(null)
被赋值为 NGX_ERROR_LOG_PATH 后
error_log=/home/wsd/桌面/nginx/LOG/error.log
name = error_log;
nlen = ngx_strlen(name);
ngx_strlen 获取字符串长度,不包括结束符
此时
nlen=36
if (nlen == 0) {
ngx_log_file.fd = ngx_stderr;
return &ngx_log;
}
此时条件不成立
p = NULL;
#if (NGX_WIN32)
if (name[1] != ':') {
#else
if (name[0] != '/') {
#endif
if (name[0] != '/') {
检查路径是否以
/
开头此时
name=/home/wsd/桌面/nginx/LOG/error.log
是以
/
开头所以当前 name 已经是绝对路径了,不需要拼接前缀
ngx_log_file.fd = ngx_open_file(name, NGX_FILE_APPEND,
NGX_FILE_CREATE_OR_OPEN,
NGX_FILE_DEFAULT_ACCESS);
以追加的方式打开 name 指向的 日志文件
此时
ngx_log_file.fd=4
if (ngx_log_file.fd == NGX_INVALID_FILE) {
ngx_log_stderr(ngx_errno,
"[alert] could not open error log file: "
ngx_open_file_n " \"%s\" failed", name);
#if (NGX_WIN32)
ngx_event_log(ngx_errno,
"could not open error log file: "
ngx_open_file_n " \"%s\" failed", name);
#endif
ngx_log_file.fd = ngx_stderr;
}
NGX_INVALID_FILE
#define NGX_INVALID_FILE -1
-1 无效的文件描述符
文件打开失败
记录错误日志
此时
ngx_log_file.fd=4
条件不成立
if (p) {
ngx_free(p);
}
由于 此次 name 在一开始是绝对路径,没有使用 p
所以 p 还是初始值 NULL
条件不成立
return &ngx_log;
最后返回 ngx_log 的地址