Linux借助Shell脚本定时分割日志

昨天,用户突然来电说”程序进不去了”,此时正值生产高峰期,这可是慌着我了,我立马尽到堡垒机去查看机器状态,我勒个去,磁盘满掉了。

仔细一看日志全存储在catalina.out,没有按日分文件,也没删除历史日志。程序比较老,也不好去动里面的东西,所以就想一个比较方便快捷的方式来处理。那边是借助Linux中的crontab加shell脚本来删除。

编写Shell脚本

1
2
3
4
5
6
#!/bin/sh
LOGS_PATH=/u01/apache-tomcat-8.0.36/logs
TODAY=$(date -d 'today' +%Y-%m-%d)
cp ${LOGS_PATH}/catalina.out ${LOGS_PATH}/catalina.out_${TODAY}.log
find /u01/apache-tomcat-8.0.36/logs -mtime +10 -name "*.*" -exec rm -Rf {} \;

find /u01/apache-tomcat-8.0.36/logs -mtime +10 -name “.“ -exec rm -Rf {} ;

/u01/apache-tomcat-8.0.36/logs :准备要进行清理的任意目录
-mtime:标准语句写法
+10:查找10天前的文件,这里用数字代表天数,+30表示查找30天前的文件
.“:希望查找的数据类型,”.jpg”表示查找扩展名为jpg的所有文件,”“表示查找所有文件
-exec:固定写法
rm -rf:强制删除文件,包括目录
{} ; :固定写法,一对大括号+空格+/+;

配置crontab

现在,我们就将前面编写好的Shell脚本添加到Linux的crontab中,在此之前,我们先了解一下crontab,cronrtab的常用参数就是crontab -e(编辑)crontab -l(查看),一下是crontab的配置格式,

1
2
3
4
5
6
7
8
9
# Example of job definition:
# .---------------- minute (0 - 59)
# | .------------- hour (0 - 23)
# | | .---------- day of month (1 - 31)
# | | | .------- month (1 - 12) OR jan,feb,mar,apr ...
# | | | | .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
# | | | | |
# * * * * * user-name command to be executed

这里,我们边使用crontab -e添加我们的脚本

1
*/5 * * * * sh del.sh

Linux借助Shell脚本定时分割日志

https://blogs.52fx.biz/posts/3001463512.html

作者

eyiadmin

发布于

2021-11-15

更新于

2024-05-31

许可协议

评论