nginx日志過大問題解決
1. 問題點
nginx默認的日志在logs/access.log,并且是一直累加寫入,時間長了就會非常大,占用過多的硬盤,如果強行刪除是很不友好的,需要重啟服務(wù);
2. 文件分割
上圖文件已經(jīng)達到了十個G左右
處理的思路肯定是生成帶有日志的一系列的文件,然后保留一定的日志,這樣才是一個正常的思路;
log_format access-upstream '$time_iso8601|$request|$remote_addr|$upstream_response_time|$http_user_agent|$http_x_forwarded_for'; map $time_iso8601 $logdate { '~^(?<ymd>\d{4}-\d{2}-\d{2})' $ymd; default 'date-not-found'; } access_log logs/access-$logdate.log ; # access_log off; # 實在不需要的話,可以將其關(guān)閉(如心跳請求,會記錄日志)
上面代碼中主要使用到了map模塊和對應(yīng)的語法:map指令使用ngx_http_map_module模塊提供的。默認情況下,nginx有加載這個模塊,除非人為的 --without-http_map_module。
ngx_http_map_module模塊可以創(chuàng)建變量,這些變量的值與另外的變量值相關(guān)聯(lián)。允許分類或者同時映射多個值到多個不同值并儲存到一個變量中,map指令用來創(chuàng)建變量,但是僅在變量被接受的時候執(zhí)行視圖映射操作,對于處理沒有引用變量的請求時,這個模塊并沒有性能上的缺失。
加上之后重新加載配置文件:
# 檢測配置是否正確 ./sbin/nginx -t #加載配置 ./sbin/nginx -s reload
觀察logs文件中已經(jīng)生成了當日的日志,這是可以清理掉之前老文件了(如果確定沒有用途的情況下),下一步就是做定時器,定時刪除過期的文件
3. 定時器定時刪除N天之前的日志
新建刪除腳本,假如保留30天日志
#!/bin/bash # 指定日志文件夾路徑 LOG_DIR="/usr/local/nginx/logs" # 獲取當前日期 CURRENT_DATE=$(date "+%Y-%m-%d") # 計算 30 天前的日期 OLD_DATE=$(date -d "30 days ago" "+%Y-%m-%d") # 遍歷日志文件夾中的文件 for logfile in "$LOG_DIR"/*; do # 提取文件名中的日期部分 filename=$(basename "$logfile") filedate=${filename#access-} filedate=${filedate%.log} # 如果文件的日期早于 OLD_DATE,則刪除該文件 if [[ "$filedate" < "$OLD_DATE" ]]; then rm "$logfile" fi done
添加定時器
crontab -e
編輯并保存
0 0 * * * /usr/local/nginx/logs/cleanup_logs.sh
查看定時器
crontab -l
這樣每天凌晨會清理掉30天之前的日志文件;
到此這篇關(guān)于nginx日志過大問題解決的文章就介紹到這了,更多相關(guān)nginx日志過大內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
keepalived+lvs 對nginx做負載均衡和高可用的操作方法
這篇文章主要介紹了keepalived+lvs 對nginx做負載均衡和高可用的操作方法,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2023-12-12詳解Nginx中HTTP的keepalive相關(guān)配置
這篇文章主要介紹了Nginx中HTTP的keepalive相關(guān)配置,以及Nginx的Httpd守護進程相關(guān)的keepalive timeout配置,需要的朋友可以參考下2016-01-01nginx 部署 vue 項目找不到j(luò)s css文件的解決方法
這篇文章主要介紹了nginx 部署 vue 項目找不到j(luò)s css文件的解決方法,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-07-07windows系統(tǒng)安裝配置nginx環(huán)境
這篇文章介紹了windows系統(tǒng)安裝配置nginx環(huán)境的方法,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06Nginx在Windows下的安裝及環(huán)境配置(將nginx作為服務(wù)運行)
這篇文章主要介紹了Nginx在Windows下的安裝及環(huán)境配置,主要是將nginx作為服務(wù)運行,需要的朋友可以參考下2018-11-11解決nginx:[emerg]?getpwnam(“nginx“)failed報錯問題
編譯安裝nginx時,啟動服務(wù)報錯nginx:[emerg]getpwnam("nginx")failed,原因是沒有為nginx創(chuàng)建用戶,解決方法是創(chuàng)建一個nginx用戶,該用戶是你在編譯時指定的用戶2025-02-02