crontab+shell命令按照文件大小切割tomcat日志

业务场景:基于cronolog按日期切割日志之后,会出现某天的日志出现存储很大的情况,用notepad++打开的时候比较慢,查询的时候也比较卡,响应很慢
解决方案:通过crontab+shell命令将每天的日志进行监控并按照文件大小切割tomcat日志,每100M切割
解决步骤:
(1)安装crontab:yum install crontabs
(2)新建autocutcatalina.sh:路径/data/script/autocutcatalina.sh
(3)写入shell命令:vim /data/script/autocutcatalina.sh 
(4)shell命令:
#!/bin/bash
log_path=/home/apache-tomcat-6.0.47/logs
d=`date +%Y-%m-%d`
d4=`date +%H-%M-%S`
filename=${log_path}/catalina.$d.out  
filesize=`ls -l $filename | awk '{ print $5 }'`  
maxsize=$((1024*1024*100))  
if [ $filesize -ge $maxsize ]  
then  
    cd ${log_path} && cp catalina.$d.out ${log_path}/catalina.$d.out.${d4}.log
echo > catalina.$d.out  
fi
(5)赋权限:chmod +x /data/script/autocutcatalina.sh
(6)设置时程表:crontab -e
(7)输入执行计划:每分钟执行一次
*/1 * * * * /data/script/autocutcatalina.sh
(8)监控crontab执行日志:tail -f /var/log/cron

你可能感兴趣的:(tomcat)