Nginx 日志記錄

1.日志類型

    · access_log : 記錄訪問的ip、用戶、路徑和其他訪問信息
    · error_log : 記錄服務(wù)器運行時相關(guān)信息

2.日志級別

    · debug : 調(diào)試級別 記錄信息最多
    · info : 普通級別
    · notice : 需要注意的信息
    · warn : 警告信息
    · error : 錯誤信息
    · crit : 嚴重錯誤信息

3.日志設(shè)置

    · access_log  on/off  (打開或關(guān)閉日志記錄功能)
    · access_log   存儲路徑   輸出格式 
  # 可以設(shè)置到http、location、server、limit_except 配置位置

4.日志格式設(shè)置

   log_format  json  '{"@timestamp":"$time_iso8601",'
                  '"@version":"1",'
                  '"client":"$remote_addr",'
                  '"url":"$uri",'
                  '"status":"$status",'
                  '"domain":"$host",'
                  '"host":"$server_addr",'
                  '"size":"$body_bytes_sent",'
                  '"responsentime":"$request_time",'
                  '"referer":"$http_referer",'
                  '"useragent":"$http_user_agent",'
                  '"upstreampstatus":"$upstream_status",'
                  '"upstreamaddr":"$upstream_addr",'
                  '"upstreamresponsetime":"$upstream_response_time"'
                   '}';

5.日志格式參數(shù)

 $args                    #請求中的參數(shù)值
 $query_string            #同 $args
 $arg_NAME                #GET請求中的NAME值
 $is_args                 #如果請求中有參數(shù),值為"?",否則為空字符串
 $uri                     #請求中的當(dāng)前URI(不帶請求參數(shù),參數(shù)位于$args),可以不同于瀏覽器傳遞的$request_uri的值,它可以通過內(nèi)部重定向,或者使用index指令進行修改,$uri不包含主機名,如"/foo/bar.html"。
 $document_uri            #同 $uri
 $document_root           #當(dāng)前請求的文檔根目錄或別名
 $host                    #優(yōu)先級:HTTP請求行的主機名>"HOST"請求頭字段>符合請求的服務(wù)器名.請求中的主機頭字段,如果請求中的主機頭不可用,則為服務(wù)器處理請求的服務(wù)器名稱
 $hostname                #主機名
 $https                   #如果開啟了SSL安全模式,值為"on",否則為空字符串。
 $binary_remote_addr      #客戶端地址的二進制形式,固定長度為4個字節(jié)
 $body_bytes_sent         #傳輸給客戶端的字節(jié)數(shù),響應(yīng)頭不計算在內(nèi);這個變量和Apache的mod_log_config模塊中的"%B"參數(shù)保持兼容
 $bytes_sent              #傳輸給客戶端的字節(jié)數(shù)
 $connection              #TCP連接的序列號
 $connection_requests     #TCP連接當(dāng)前的請求數(shù)量
 $content_length          #"Content-Length" 請求頭字段
 $content_type            #"Content-Type" 請求頭字段
 $cookie_name             #cookie名稱
 $limit_rate              #用于設(shè)置響應(yīng)的速度限制
 $msec                    #當(dāng)前的Unix時間戳
 $nginx_version           #nginx版本
 $pid                     #工作進程的PID
 $pipe                    #如果請求來自管道通信,值為"p",否則為"."
 $proxy_protocol_addr     #獲取代理訪問服務(wù)器的客戶端地址,如果是直接訪問,該值為空字符串
 $realpath_root           #當(dāng)前請求的文檔根目錄或別名的真實路徑,會將所有符號連接轉(zhuǎn)換為真實路徑
 $remote_addr             #客戶端地址
 $remote_port             #客戶端端口
 $remote_user             #用于HTTP基礎(chǔ)認證服務(wù)的用戶名
 $request                 #代表客戶端的請求地址
 $request_body            #客戶端的請求主體:此變量可在location中使用,將請求主體通過proxy_pass,fastcgi_pass,uwsgi_pass和scgi_pass傳遞給下一級的代理服務(wù)器
 $request_body_file       #將客戶端請求主體保存在臨時文件中。文件處理結(jié)束后,此文件需刪除。如果需要之一開啟此功能,需要設(shè)置client_body_in_file_only。如果將次文件傳 遞給后端的代理服務(wù)器,需要禁用request body,即設(shè)置 proxy_pass_request_body off,fastcgi_pass_request_body off,uwsgi_pass_request_body off,or scgi_pass_request_body off
 $request_completion      #如果請求成功,值為"OK",如果請求未完成或者請求不是一個范圍請求的最后一部分,則為空
 $request_filename        #當(dāng)前連接請求的文件路徑,由root或alias指令與URI請求生成
 $request_length          #請求的長度 (包括請求的地址,http請求頭和請求主體)
 $request_method          #HTTP請求方法,通常為"GET"或"POST"
 $request_time            #處理客戶端請求使用的時間,單位為秒,精度毫秒; 從讀入客戶端的第一個字節(jié)開始,直到把最后一個字符發(fā)送給客戶端后進行日志寫入為止。
 $request_uri             #這個變量等于包含一些客戶端請求參數(shù)的原始URI,它無法修改,請查看$uri更改或重寫URI,不包含主機名,例如:"/cnphp/test.php?arg=freemouse"
 $scheme                  #請求使用的Web協(xié)議,"http" 或 "https"
 $server_addr             #服務(wù)器端地址,需要注意的是:為了避免訪問linux系統(tǒng)內(nèi)核,應(yīng)將ip地址提前設(shè)置在配置文件中
 $server_name             #服務(wù)器名
 $server_port             #服務(wù)器端口
 $server_protocol         #服務(wù)器的HTTP版本,通常為 "HTTP/1.0" 或 "HTTP/1.1"
 $status                  #HTTP響應(yīng)代碼
 $time_iso8601            #服務(wù)器時間的ISO 8610格式
 $time_local              #服務(wù)器時間(LOG Format 格式)
 $cookie_NAME             #客戶端請求Header頭中的cookie變量,前綴"$cookie_"加上cookie名稱的變量,該變量的值即為cookie名稱的值
 $http_NAME               #匹配任意請求頭字段;變量名中的后半部分NAME可以替換成任意請求頭字段,如在配置文件中需要獲取http請求頭:"Accept-Language",使用$http_accept_language即可
 $http_host               #請求地址,即瀏覽器中你輸入的地址(IP或域名)
 $http_referer            #url跳轉(zhuǎn)來源,用來記錄從那個頁面鏈接訪問過來的
 $http_user_agent         #用戶終端瀏覽器等信息
 $sent_http_NAME          #可以設(shè)置任意http響應(yīng)頭字段;變量名中的后半部分NAME可以替換成任意響應(yīng)頭字段,如需要設(shè)置響應(yīng)頭Content-length,
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容