> 백엔드 개발 > PHP 튜토리얼 > 쉘 스크립트는 Nginx 로그를 분할하고 정기적으로 정리합니다.

쉘 스크립트는 Nginx 로그를 분할하고 정기적으로 정리합니다.

WBOY
풀어 주다: 2016-07-29 08:56:03
원래의
1214명이 탐색했습니다.

기본적으로 nginx는 하나의 액세스 로그만 생성합니다. 매일 누적되면 로그 파일이 매우 커집니다. 로그 분석이 필요한 경우 스크립트 분석을 사용하거나 로컬 분석을 위해 로그를 다운로드하는 것이 쉽지 않습니다. . 편리한. 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 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시를 의미하며, 다음의 " * * * "는 "를 의미합니다. 일, 월, 연도"이며 정의할 필요가 없습니다
2. "/usr/local/nginx/cut_nginx_log.sh"는 쉘 경로입니다.

알았어! 작업이 완료되면 로그는 매일 0시에 자동으로 잘라내어 웹사이트 로그 파일 이름을 딴 해당 디렉터리에 저장됩니다.

3. 표시
web1.log => web1/web1-20160322.log web1/web1-20160323.log
web2.log => -20160322.log web2/web2-20160323.log

블로그: http://www.webyang.net/Html/web/article_255.html

위 내용은 Nginx 로그를 분할하고 정기적으로 정리하는 쉘 스크립트를 소개하며, PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되기를 바랍니다.

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿