工做中常常会碰到服务日志占满服务器磁盘,若是不去清理,服务就可能没法正常工做。适当提升日志的打印级别,如info级别提升到warn能够临时缓解下,但也不长久之际,nginx
还得写个脚本定时清理下。bash
- #!/bin/bash
- #clearLog.sh
-
- nginxDir=/usr/local/nginx/logs/*
- devInfo=($(df -l | awk '{print $1}')) #日志所处的磁盘
- perInfo=($(df -l | awk '{print int($5)}')) #磁盘使用率
-
- for i in `seq 0 ${#perInfo[@]}`;
- do
- if [[ ${devInfo[i]} = '/dev/xvda1' ]] && [[ ${perInfo[i]} -ge 80 ]];
- then
-
- for file in $nginxDir;
- do
- exist=`echo $file | awk '{if(match($0,/\.log/)) print "yes"}'`;
- if [[ -f $file ]] && [[ ${exist} = yes ]];
- then
- echo '' > $file;
- echo $(date) $file "clear log ok!" >> /var/log/clear.log ;
- fi;
- done
- fi;
-
-
- done
肯定日志所处磁盘的使用状况,通常使用率达到80%就能够进行清理了。服务器
接着起个定时任务:日志
crontab -ecrontab
输入:awk
0/30 * * * * /xxx/clearLog.shdate
每隔30分钟检测一次磁盘使用状况定时任务