一、问题描述
由于最近公司阿里云服务器磁盘经常被占满,发现是由于生成大量的日志文件导致的(特别的记录服务之间心跳的日志,每天好几个G),所有需要每天定时去清理日志文件。
二、编写清理文件脚本
vi auto_del_15_days_ago_log.sh
#清理多个应用的日志文件
find /xxx/xxx/xxx/Tomcat/logs -mtime +15 -name "*201*" -exec rm -rf {} \;
find /xxx/xxx/xxx/logs -mtime +15 -name "*201*" -exec rm -rf {} \;
find /xxx/xxx/xxx/Tomcat/logs -mtime +15 -name "*201*" -exec rm -rf {} \;
find /xxx/xxx/xxx/bin -mtime +15 -name "*201*" -exec rm -rf {} \;
修改该脚本文件的权限:
chmod +x auto_del_15_days_ago_log.sh
三、设置定时执行auto_del_15_days_ago_log.sh
#这是执行计划
crontab -e
#将 执行脚本加入到系统计划任务,到点自动执行
10 0 * * * /xxx/xxx/auto_del_15_days_ago_log.sh >/dev/null 2>&1
这里的设置是每天凌晨0点10分执行auto_del_15_days_ago_log.sh 文件进行数据清理任务了。
关于 >/dev/null 2>&1 简介:
linux在执行shell命令之前,就会确定好所有的输入输出位置,并且从左到右依次执行重定向的命令,所以>/dev/null 2>&1的作用就是让标准输出重定向到/dev/null中(丢弃标准输出),然后错误输出由于重用了标准输出的描述符,所以错误输出也被定向到了/dev/null中,错误输出同样也被丢弃了。执行了这条命令之后,该条shell命令将不会输出任何信息到控制台,也不会有任何信息输出到文件中。
四、查看定时任务是否设置成功
crontab -l
(注:若是追加的文件日志,上面的清理就没什么作用了。如:Tomcat/logs/catalina.out 日志,可以先备份一份压缩或者通过同步策略同步到其他服务器备份,然后追加清空现日志文件。命令: echo " " > /xxx/xxx/Tomcat/logs/catalina.out )
完成以上步骤,服务器就会定期清理这部分日志了,基本上不会再收到服务器磁盘空间不足类的报警信息了,哈哈。。。