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