知识屋:更实用的电脑技术知识网站
所在位置:首页 > 操作系统 > linux

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

发布时间:2014-09-05 16:30:48作者:知识屋

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.zhishiwu.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
(免责声明:文章内容如涉及作品内容、版权和其它问题,请及时与我们联系,我们将在第一时间删除内容,文章内容仅供参考)
收藏
  • 人气文章
  • 最新文章
  • 下载排行榜
  • 热门排行榜