每隔一段时间服务器磁盘空间总会被应用输出日志打满,导致应用出现服务异常等问题,故而需要配置自动清理日志文件脚本,配合crond定时任务实现自动化执行。
执行创建文件命令touch shell.sh
,并编辑输入以下脚本:
#!/bin/bash
# 日志文件存放路径
logPath=/data/logs
# 截取根目录磁盘的占用率
disk=$(df -h|grep "/$"|awk '{print int($5)}')
if [ $disk -gt 85 ]; then
for i in `/usr/bin/ls -thr ${logPath} |grep '*.log' |head -12`
do
rm -rf ${logPath}/$i
done;
echo "成功清理日志文件" >> /data/log/nation/shell.txt
else
date >> ${logPath}/shell.txt && echo "磁盘空间占用率小于85%" >> ${logPath}/shell.txt
fi
说明:
1.#!/bin/bash:声明shell命令解析器,否则使用系统默认的
2.以上脚本命令的意思为先获取磁盘空间占用率大小,若大于85,则列出时间倒序的以.log为后缀的前12个文件并遍历删除,并且打印日志到shell.txt文件。
因为是shell脚本,所以需要执行权限:
chmod -R 777 shell.sh
可以自测脚本是否正确:
bash -v shell.sh
接着配置crontab定时任务:
crontab -uroot -e
在最后编辑输入并保存退出(自行研究cron表达式,这里配置每两分钟执行一次):
*/2 * * * * /data/logs/shell.sh >>/data/logs/shell.txt
查看配置的cron定时任务:
crontab -uroot -l
查看shell.txt是否有日志输出(有输出即表明脚本配置生效):
cat shell.txt
假如没有生效,可重启crond服务:
service crond restart
至此,定时自动清理日志文件任务完成!