nginx的log日志分為access log 和 error log
access log :記錄了哪些用戶脚乡,哪些頁(yè)面以及用戶瀏覽器丙曙、ip和其他的訪問(wèn)信息
error log :是記錄服務(wù)器錯(cuò)誤日志
access.log日志的形式如下:
10.0.0.1 - - [09/Nov/2021:17:01:16 +0800] "GET / HTTP/1.1" 200 3959 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:94.0) Gecko/20100101 Firefox/94.0" "-"
10.0.0.1 - - [09/Nov/2021:17:01:16 +0800] "GET /static/css/main.660bf0c2.chunk.css HTTP/1.1" 200 8766 "http://10.0.0.61/" "Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:94.0) Gecko/20100101 Firefox/94.0" "-"
從上面我們可以看出幾部分信息:
1.客戶端(用戶)IP地址揩魂。如:上例中的10.0.0.1
2.訪問(wèn)時(shí)間。如:上例中的[09/Nov/2021:17:01:16 +0800]
3.請(qǐng)求方式(GET或者POST等)夷狰。如:上例中的 GET
4.請(qǐng)求的url地址(目標(biāo)url地址)的host袜腥。如:上例中的 /....
5.請(qǐng)求url地址(去除host部分)。如:上例中的 /static/css/main.660bf0c2.chunk.css
6.請(qǐng)求狀態(tài)胀莹。如:上例中的 "200"
7.請(qǐng)求頁(yè)面大小基跑,默認(rèn)為B(byte)。如:上例中的3959
8.來(lái)源頁(yè)面描焰,即從哪個(gè)頁(yè)面轉(zhuǎn)到本頁(yè)媳否,專業(yè)名稱叫做“referer”。如:上例中的 "http://10.0.0.61/"
- 用戶瀏覽器其他信息荆秦,瀏覽器版本篱竭、瀏覽器類型等。如:上例中的 "Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:94.0) Gecko/20100101 Firefox/94.0"
其實(shí)nginx access日志的格式不是一成不變的步绸,是可以自定義的掺逼。
在nginx的nginx.conf配置文件找到:log_format 這里就是日志的格式
看一下和上述日志匹配的log格式設(shè)置:
log_format main '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
相關(guān)說(shuō)明解釋:
$remote_addr
客戶端的ip地址(代理服務(wù)器,顯示代理服務(wù)ip)
$remote_user
用于記錄遠(yuǎn)程客戶端的用戶名稱(一般為“-”)
$time_local
用于記錄訪問(wèn)時(shí)間和時(shí)區(qū)
$request
用于記錄請(qǐng)求的url以及請(qǐng)求方法
$status
響應(yīng)狀態(tài)碼瓤介,例如:200成功吕喘、404頁(yè)面找不到等赘那。
$body_bytes_sent
給客戶端發(fā)送的文件主體內(nèi)容字節(jié)數(shù)
$http_referer
可以記錄用戶是從哪個(gè)鏈接訪問(wèn)過(guò)來(lái)的
$http_user_agent
用戶所使用的代理(一般為瀏覽器)
$http_x_forwarded_for
可以記錄客戶端IP,通過(guò)代理服務(wù)器來(lái)記錄客戶端的ip地址
配置access log日志的存儲(chǔ)位置及文件氯质,注意:access.log文件是可以按日期進(jìn)行分割的募舟,方便查看及處理