nginx是沒有以日期格式做爲文件名來存儲的,全部的日誌都是以一個名字來存儲,長久以來日誌文件會變得很大。這樣很是不利於分析。
雖然nginx沒有這個功能但咱們能夠寫一個小腳本配合計劃任務來達到這樣的效果。
腳本代碼以下(cutn/usr/local/tool/cutnginxlog.sh)
#!/bin/sh
# Program:
# Auto cut nginx log script.
# 2012/2/5 b4dboy First release QQ:137 51 52 53
# nginx日誌路徑 www.2cto.com
LOGS_PATH=/var/wwwroot/bbs/logs
TODAY=$(date -d 'today' +%Y-%m-%d)
# 移動日誌並更名
mv ${LOGS_PATH}/error.log ${LOGS_PATH}/error_${TODAY}.log
mv ${LOGS_PATH}/access.log ${LOGS_PATH}/access_${TODAY}.log
# 向nginx主進程發送從新打開日誌文件的信號
kill -USR1 $(cat /usr/local/nginx/logs/nginx.pid)
注意腳本中的兩個路徑,還要給執行的權限(chmod +x cutnginxlog.sh)。
接下來就是添加計劃任務讓他定時運行了,以root用戶執行以下命令。
echo '59 23 * * * root /usr/local/tool/cutnginxlog.sh >> /var/logs/cutnginxlog.log 2>&1' >> /etc/crontab
意思就是在天天的23點59執行腳本。
nginx