shell脚本切割tomcat的日志文件

鉴于在调试logback和log4j的文件切割一直没法成功,随性用shell写个脚本用来切割tomcat下的日志文件(你们若是有在logback或log4j使用文件切割成功的话,能够留下使用方式,先谢谢了)linux

1:废话少说,直接贴上脚本:shell

#!/bin/sh
log_dir=/var/log/tomcat monitor_file=$1 #tomcat目录下的catalina.out文件的绝对路径 file_size=`du -m $monitor_file | awk '{print $1}'` if [ $file_size -ge 100 ] then if [ ! -d $log_dir ] then mkdir /var/log/tomcat #建立保存切割文件目录,这个路径能够自行修改,保存到你想要的目录 fi cp $1 /var/log/tomcat/log-`date +%Y-%m-%d-%H%M%S`.log #保存日志文件 echo `date +%Y-%m-%d-%H:%M:%S`":文件切割" >>/var/log/tomcat/split.log #记录切割日志 echo "" > $1 #清空tomcat的log/catalina.out文件内容 fi

说明:这个脚本很简单,linux用个定时器没分钟定时扫描日志文件的大小,就是当文件大于100M的时候,先把文件复制到指定的目录,再清空原先tomcat的日志文件。这里是用crontab来使用定时器,至于这个命令的语法在这里就很少说,有兴趣的能够自行google,这里仍是有个小小的不足,由于是按每分钟定时去扫描日志文件,因此最后切割文件大小仍是会在100~102M之间。apache

而后就用定时器,定时执行这个脚本tomcat

2:用 crontab -e 编辑定时器代码学习

*/1 * * * *  sh /lee_js/monitor_script.sh  /opt/apache-tomcat-7.0.67/logs/catalina.out #第一个路径是脚本的路径,第二个参数是tomcat下catalina.out文件的绝对路径

 

而后保存google

至此搞定日志切割spa

注:若没有crontab命令 可以使用 yum安装:调试

yum install vixie-cron
yum install crontabs

若文章在表述和代码方面若有不妥之处,欢迎批评指正。留下你的脚印,欢迎评论!但愿能互相学习日志

相关文章
相关标签/搜索