以日期为文件名来存储nginx日志

来源:岁月联盟 编辑:exp 时间:2012-02-23
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执行脚本。
 
ps:如果要分析某个时候的日志的话利用Navicat for MySQL的导入功能把nginx日志导入到mysql接下来你想怎么分析就只是构造sql的事了

摘自 B4dboy's Blog