首页  >  文章  >  后端开发  >  Shell脚本分割Nginx日志,并定期清理

Shell脚本分割Nginx日志,并定期清理

WBOY
WBOY原创
2016-07-29 08:56:031173浏览

默认nginx只会生成一个访问日志,在每天的积累下,日志文件会变的非常大,如果需要做一下日志的分析,无论是使用脚本分析,还是把日志下载本地分析,都不太方便。每天分割Nginx的访问日志,有利于分析日志。

一:新建脚本文件

vim cut_nginx_log.sh
<ol>
<li value="1"><span>#!/bin/bash</span></li>
<li><span>#nginx access log segmentation shell script</span></li>
<li><span>#www.webyang.net</span></li>
<li><span>#日志目录</span></li>
<li>
<span>log_dir</span><span>=</span><span>"/usr/local/nginx/logs/"</span>
</li>
<li><span>cd $log_dir</span></li>
<li>
<span>time</span><span>=</span><span>`date +%Y%m%d --date="-1 day"`</span>
</li>
<li><span>#nginx启动目录</span></li>
<li>
<span>nginx_dir</span><span>=</span><span>"/etc/init.d/nginx"</span>
</li>
<li><span>#日志保存天数</span></li>
<li>
<span>save_days</span><span>=</span><span>15</span>
</li>
<li><span>#日志文件名所处'/'分割的位置,key('/'数+1)</span></li>
<li>
<span>num</span><span>=</span><span>6</span><span>;</span>
</li>
<li><span> </span></li>
<li><span>#此处待优化(取得文件不带后缀的文件名)</span></li>
<li>
<span>website</span><span>=</span><span>`ls $log_dir*.log | xargs -n 1 | cut -f 1 -d "." | cut -f $num -d "/"`</span>
</li>
<li><span>#日志目录下所有的日志文件为文件夹,循环新建对应的时间文件</span></li>
<li>
<span>for</span><span> i </span><span>in</span><span> $website</span>
</li>
<li><span>do</span></li>
<li><span>#判断目录是否存在</span></li>
<li>
<span>if</span><span>[</span><span>!</span><span>-</span><span>d $log_dir$i </span><span>];</span><span>then</span>
</li>
<li>
<span>        mkdir </span><span>"$i"</span>
</li>
<li><span>fi</span></li>
<li>
<span>    mv $log_dir$i</span><span>.</span><span>log $log_dir$i</span><span>/</span><span>$i</span><span>-</span><span>$time</span><span>.</span><span>log</span>
</li>
<li><span>done</span></li>
<li><span> </span></li>
<li><span>#删除设置天数前的数据</span></li>
<li>
<span>find $log_dir</span><span>/</span><span>-</span><span>mtime </span><span>+</span><span>$save_days </span><span>-</span><span>exec</span><span> rm </span><span>-</span><span>rf </span><span>{}</span><span> \;</span>
</li>
<li><span> </span></li>
<li><span>#平滑启动nginx</span></li>
<li><span>$nginx_dir  reload</span></li>
</ol>
二、设置crontab,每天定时切割
如果没有安装,运行yum  -y install crontabs 安装。
输入crontab -e命令(详情参考:http://www.webyang.net/Html/web/article_232.html),
输入下面的内容:
00 00 * * * /bin/bash /usr/local/nginx/cut_nginx_log.sh
1、00 00意思为00分00点,也就是凌晨0点,后面“ * * * ”为“ 日 月 年 ”无需定义
2、"/usr/local/nginx/cut_nginx_log.sh" 为你的shell的路径。

OK ! 大功告成,每天的0时就会自动完成日志的切割并存在相应的以网站日志文件命名的目录中。

三、展示
web1.log => web1/web1-20160322.log web1/web1-20160323.log
web2.log => web2/web2-20160322.log web2/web2-20160323.log

博客:http://www.webyang.net/Html/web/article_255.html

以上就介绍了Shell脚本分割Nginx日志,并定期清理,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn