工作中经常会碰到服务日志占满服务器磁盘,如果不去清理,服务就可能无法正常工作。适当提高日志的打印级别,如info级别提高到warn可以临时缓解下,但也不长久之际,

还得写个脚本定时清理下。

#!/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 -e

输入:

0/30 * * * *  /xxx/clearLog.sh

每隔30分钟检测一次磁盘使用情况



Logo

更多推荐