线上有一个日志系统,放在/data/log目录,有时候出现磁盘空间不足的情况,所以写了一个脚本,删除前一天的日志文件。

内容如下:


#!/bin/bash


eve=`date -d "1 day ago" +"%Y%m%d"`

startime=`date +%Y-%m-%d" "%H:%M:%S`

echo "######################################" >> /opt/clean_log.log


echo "$startime 开始删除文件/data/log/messages-$eve" >> /opt/clean_log.log

rm -rf /data/log/messages-$eve


if [ ! -e /data/log/messages-$eve ];then

        echo "删除成功" >> /opt/clean_log.log

else

        echo "删除失败" >> /opt/clean_log.log

fi


startime=`date +%Y-%m-%d" "%H:%M:%S`

echo "$startime 开始切割文件/var/log/message" >> /opt/clean_log.log

cd /var/log/

mv -f messages messages-$eve


if [ -e /var/log/messages-$eve ];then

        echo "切割成功" >> /opt/clean_log.log

else

        echo "切割失败" >> /opt/clean_log.log

fi


/etc/init.d/rsyslog restart >> /dev/null


if [ `echo $?` -eq "0" ];then

        echo "重启rsyslog服务成功" >> /opt/clean_log.log

else

        echo "重启rsyslog服务失败" >> /opt/clean_log.log

fi


startime=`date +%Y-%m-%d" "%H:%M:%S`

echo "$startime 开始删除文件/var/log/message-$eve" >> /opt/clean_log.log

rm -rf /var/log/messages-$eve


if [ ! -e /var/log/messages-$eve ];then

        echo "删除文件成功" >> /opt/clean_log.log

else

        echo "删除文件失败" >> /opt/clean_log.log

fi


说明:

rm -rf删除的时候,不管文件是否存在

用 echo $? 判断的时候,始终都是0

所以用! -e $filename 判断文件不存在,就说明文件删除成功了。


/var/log/message是系统日志,虽然系统默认会自动切割,但不是每天都会切割。

所以脚本里面进行了切割。

一旦切割之后,message不会自动生成,需要重启rsyslog服务才会生成。


最后创建任务计划,每天晚上定期执行就可以了。