日期:2014-05-16  浏览次数:20721 次

发布一个自动清除过期文件的脚本
本帖最后由 kestudio123 于 2013-04-19 16:21:43 编辑
最近要做系统的部署,在机器上运行大量的java程序,而且机器要放在一个地方跑,不能经常维护。

程序不具备自动删除日志功能,而空间非常小,往往过几天一有异常,就出现爆机的现象。

所以下定决心,决定写一个自动删除过期文件的脚本。脚本要求简单,通用,容易控制,对系统100%没有依赖性!!!!总之是绝对是轻量级的要求。

原理如下:通过find命令查找指定目录下一定天数以前的文件,然后清楚。脚本读取配置后在后台跑,一天执行一次。

由于CSDN好像上传不了附件,我这里简单贴出代码,当做分享

这小型程序住包括三个文件,还有一个使用说明,放在自定义的一个目录下就可以了(比如叫做/opt/auto_clean)


主程序:auto_clean.sh
目标目录配置文件:path_list.txt
用后台方式启动主程序:start_background.sh

auto_clean.sh------主程序

#!/bin/sh
##########################################################

### this program will check up outdate files every day  ##

##########################################################
time=`date "+%y-%m-%d  %H:%M:%S"`
echo -------start in $time------- >> ./log.txt

### ----------如果天数没设定,那么默认为五天-------#####

while true;do
while read var_a var_b;do
  if [ ! $var_b ]; then
     var_b=5;
  fi
  outdate_files=`find $var_a -type f -maxdepth 1 -mtime +$var_b`
  for name in $outdate_files;do
    time=`date "+%y-%m-%d  %H:%M:%S"`
    echo $time $name >> ./log.txt 2>&1
    rm -f $name >> ./log.txt 2>&1
  done;
done < ./path_list.txt
sleep 1d
done;



path_list.txt-----读取的目标目录配置文件,根据需要自行修改

/opt/mcq/daemons/tcs/log 5
/opt/mcq/daemons/rem/log 5
/opt/mcq/daemons/rtmm/log 5
/opt/mcq/daemons/rem/log 5
/opt/mcq/daemons/autofind/log 5
/opt/mcq/daemons/dysync/log 5
/opt/mcq/servers/jboss-6.0.0.Final/server/abc/log 5
/opt/mcq/servers/jboss-6.0.0.Final/server/bcd/log 5
/opt/mcq/servers/jboss-6.0.0.Final/server/efg/log 5
/opt/mcq/servers/jboss-6.0.0.Final/server/hij/log 5



auto_clean.sh-------用于让自动清除任务挂在后台的时候执行的脚本,一般都是通过此脚本来启动整个程序的


#!/bin/sh
echo ""
echo "The watching directorys........."
echo ""
while read var_a var_b;do
echo $var_a
done < ./path_list.txt
echo ""

./auto_clean.sh  &


好了,接下来就要叫大家怎么使用了。至于如何填写配置文件,和如何做到快速定位在一个目录下的所有目录中的日志文件所在,我们可以查看里面的readme.txt文件


readme.txt


----------------------
path_list.txt中填写要自动目录下删除过期文件的目录(绝对路径)

格式为(绝对路径+ 保留天数):

目录a 5
目录b 4
目录c 5

如果天数没设定,那么默认为五天

example:

可以用命令(思路是找到一个大目录下所有以"log"命名的文件夹) 
 find /opt/edsp  -name "log" -exec echo {} 5  \;
来找到要监视的日志目录列表

一般情况是是,程序已经运行,log目录已经生成,否则找不到。

-----------------------


配置完成后,启动s