ホームページ  >  記事  >  バックエンド開発  >  シェル スクリプトは Nginx ログを分割し、定期的にクリーンアップします。

シェル スクリプトは Nginx ログを分割し、定期的にクリーンアップします。

WBOY
WBOYオリジナル
2016-07-29 08:56:031173ブラウズ

デフォルトでは、nginx はアクセス ログを 1 つだけ生成します。毎日蓄積されると、ログ ファイルが非常に大きくなります。ログを分析する必要がある場合、スクリプト分析を使用したり、ローカル分析用にログをダウンロードしたりするのは不便です。 Nginx のアクセス ログを毎日分割すると、ログの分析に役立ちます。

1: 新しいスクリプトファイルを作成します

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>
2. crontab をセットアップし、毎日定期的にカットします。インストールされていない場合は、yum -y install crontab を実行してインストールします。
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 は午前 0 時を意味し、次の「* * *」は「日、月、年」を意味します。定義する必要はありません。「/usr/local/nginx/cut_nginx_log.sh」はシェルへのパスです。

OK! これで完了です。ログは毎日 0:00 に自動的に切り取られ、Web サイトのログ ファイルにちなんで名付けられた対応するディレクトリに保存されます。

3.

web1.log => web1/web1-20160322.log

web1/
web1-20160322.log web2-20160323 を表示します。ログ
ブログ: http://www.webyang.net/Html/web/article_255.html

上記は、Nginx ログを分割し、定期的にクリーンアップするためのシェル スクリプトを内容も含めて紹介しています。PHP チュートリアルに興味のある友人に役立つことを願っています。


声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。