在Debian系統中,要自定義Nginx日志格式,請按照以下步驟操作:
/etc/nginx/nginx.conf。使用文本編輯器打開它,如nano或vim。例如,使用nano編輯器,運行以下命令:sudo nano /etc/nginx/nginx.conf
http塊中,定義一個新的日志格式。在http塊內添加以下代碼,自定義您想要的日志格式。例如,創建一個包含客戶端IP、請求時間、HTTP方法、URL、HTTP狀態碼和用戶代理的日志格式:http {
...
log_format custom '$remote_addr - $remote_user [$time_local] '
'"$request" $status $body_bytes_sent '
'"$http_referer" "$http_user_agent"';
...
}
這里的custom是自定義日志格式的名稱,您可以根據需要更改它。變量(如$remote_addr和$request)表示日志中的不同部分。
server或location塊中,使用新定義的日志格式。將access_log指令與您在步驟2中創建的自定義日志格式名稱一起使用。例如:server {
...
access_log /var/log/nginx/access.log custom;
...
}
這將使Nginx使用您在步驟2中定義的自定義日志格式記錄訪問日志。確保將/var/log/nginx/access.log替換為您希望存儲日志文件的路徑。
保存更改并退出文本編輯器。
檢查Nginx配置文件的語法是否正確。運行以下命令:
sudo nginx -t
如果配置文件語法正確,您將看到以下輸出:
nginx: configuration file /etc/nginx/nginx.conf test is successful
sudo systemctl reload nginx
現在,Nginx將使用您自定義的日志格式記錄訪問日志。