linux自动清理日志脚本
解决方案有装宝塔面板的可以安装一个linux日志清理插件 可清理日志如下
文件目录:/var/log/wtmp文件大小:6.75 KB文件目录:/var/log/mail.log.3.gz文件大小:10.63 MB文件目录:/var/log/mem.log文件大小:226 B文件目录:/var/log/kern.log.1文件大小:131.66 KB文件目录:/var/log/syslog.1文件大小:100.68 MB文件目录:/var/log/mail.log.2.gz文件大小:18.33 MB文件目录:/var/log/auth.log文件大小:270.11 KB文件目录:/var/log/dpkg.log.1文件大小:22.92 KB文件目录:/var/log/btmp.1文件大小:10.88 KB文件目录:/var/log/ufw.log.2.gz文件大小:15.92 KB文件目录:/var/log/syslog.2.gz文件大小:3.33 MB文件目录:/var/log/mail.log文件大小:292.19 MB文件目录:/var/log/btmp文件大小:57.75 KB文件目录:/var/log/xrdp-sesman.log文件大小:950 B文件目录:/var/log/syslog.6.gz文件大小:3.03 MB文件目录:/var/log/syslog.4.gz文件大小:2.96 MB文件目录:/var/log/ufw.log文件大小:54.85 KB文件目录:/var/log/mail.log.4.gz文件大小:681.32 KB文件目录:/var/log/ufw.log.3.gz文件大小:11.54 KB文件目录:/var/log/syslog.5.gz文件大小:2.78 MB文件目录:/var/log/auth.log.2.gz文件大小:42.95 KB文件目录:/var/log/lastlog文件大小:292 B文件目录:/var/log/ufw.log.4.gz文件大小:4.58 KB文件目录:/var/log/boot.log文件大小:7.15 KB文件目录:/var/log/kern.log.2.gz文件大小:25.63 KB文件目录:/var/log/ufw.log.1文件大小:94.30 KB文件目录:/var/log/kern.log.3.gz文件大小:20.84 KB文件目录:/var/log/dpkg.log文件大小:2.57 KB文件目录:/var/log/syslog.7.gz文件大小:2.90 MB文件目录:/var/log/mail.err.1文件大小:289.92 KB文件目录:/var/log/mail.err文件大小:139.46 KB文件目录:/var/log/mail.log.1文件大小:493.41 MB文件目录:/var/log/syslog文件大小:93.80 MB文件目录:/var/log/kern.log文件大小:129.10 KB文件目录:/var/log/ecs_network_optimization.log文件大小:702 B文件目录:/var/log/syslog.3.gz文件大小:3.02 MB文件目录:/var/log/wtmp.1文件大小:10.88 KB文件目录:/var/log/cloud-init.log文件大小:107.22 KB文件目录:/var/log/auth.log.3.gz文件大小:39.76 KB文件目录:/var/log/mail.err.3.gz文件大小:21.47 KB文件目录:/var/log/mail.err.2.gz文件大小:20.04 KB文件目录:/var/log/auth.log.1文件大小:555.16 KB文件目录:/var/log/auth.log.4.gz文件大小:17.86 KB文件目录:/var/log/tallylog文件大小:8.06 KB文件目录:/var/log/mail.err.4.gz文件大小:9.83 KB文件目录:/var/log/kern.log.4.gz文件大小:18.30 KB
1.做自动部署系统时精简的一个脚本,主要功能是清理所有目录的日志
2.根据给定日志目录,删除时间 结合crontab进行清理日志,清理完成后,后在/var/log/deltelog/ 生成按照月的清理日志
3.扩展,因为脚本采用mtime(最后修改时间)进行删除,所以可以适用于删除过期备份等,不受文件名称的限制
shell小窍门
find –type f –print 时会根据换行或者空格来输出查找的文件,在不同的sh下有不同的反应,如果不做处理结合xargs 进行删除 更改操作,会有影响
所以需要增加 –print0 用 null来 作为边界符号,才敢结婚 xargs –o 来格式化输入
使用find 的时候 遵循最小结果集原则,find解析式从左到右,所有确保你在最左边的过滤符号能够过滤最大数据
你可以根据你的需要增加到crontab中
shell脚本
###########################
#delete log blog.duplicatedcode.com
# in_day_num: like 1 2 is delete 2day ago logs
# in_log_path like tomcat log home
###########################
in_log_path=${1}
in_day_num=${2}
tmp_delete_log=/var/log/deletelog/"
date +%Y%m
.log"deleteLog()
{
inner_num=${1}
#find log
echo "[
date
] >> start delete logs---" >> $tmp_delete_logfind ${in_log_path} -type f -mtime ${inner_num} -print0 | xargs -0 rm -rf
echo "[
date
] >> end delete logs---" >> $tmp_delete_log}
init()
{
mkdir -p /var/log/deletelog/
}
main()
{
init
if [ -z ${in_log_path} ];then
echo "[
date
] >> error log_path not init---" >> $tmp_delete_logreturn
fi
inner_day_num=+7
if [[ -n ${in_day_num} ]] && [[ ${in_day_num} -ge 1 ]] ; then
${inner_day_num}=${in_day_num}
fi
deleteLog ${inner_day_num}
}
main