定義在 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] != ':') {
#elseif (name[0] != '/') {
#endifif (prefix) {plen = ngx_strlen(prefix);} else {
#ifdef NGX_PREFIXprefix = (u_char *) NGX_PREFIX;plen = ngx_strlen(prefix);
#elseplen = 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);
#endifngx_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] != ':') {
#elseif (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_open_file-CSDN博客
此時?
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);
#endifngx_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?的地址