linux自动清理日志脚本-linux自动清理日志脚本-泓源视野

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脚本

 

复制代码 代码如下:
#!/bin/sh
###########################
#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_log
find ${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_log
return
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
本文由 泓源视野 作者:admin 发表,其版权均为 泓源视野 所有,文章内容系作者个人观点,不代表 泓源视野 对观点赞同或支持。如需转载,请注明文章来源。
9

发表评论

Protected with IP Blacklist CloudIP Blacklist Cloud
您是第8238176 位访客, 您的IP是:[18.234.202.202]