Linux下定时切割Tomcat日志并删除指定天数前的日志记录推荐

System.out和System.err都被打印到catalina.out。catalina.out不会rotate。一般在部署Tomcat后,运行久了,catalina.out文件会越来越大,对系统的稳定造成了一定的影响。

1、可通过修改conf/logging.properties日志配置文件来屏蔽掉这部分的日志信息。

[root@localhostconf]#pwd/usr/local/tomcat/conf[root@localhostconf]#cplogging.propertieslogging.propertiesbak[root@localhostconf]#vimlogging.properties251catalina.org.apache.juli.FileHandler.level=FINE261catalina.org.apache.juli.FileHandler.directory=${catalina.base}/logs271catalina.org.apache.juli.FileHandler.prefix=catalina.

将level级别设置成WARNING就可以大量减少日志的输出,当然也可以设置成OFF,直接禁用掉。

一般日志的级别有:SEVERE (highest value) WARNING INFO CONFIG FINE FINER FINEST (lowest value)

2、使用cronolog工具切分Tomcat的catalina.out日志文件

下载、安装cronolog

[root@localhostsrc]#rpm-qa|grepcronolog[root@localhostsrc]#tarzxvfcronolog-1.6.2.tar.gz[root@localhostsrc]#cdcronolog-1.6.2[root@localhostcronolog-1.6.2]#./configure[root@localhostcronolog-1.6.2]#make makeinstall[root@localhostcronolog-1.6.2]#whichcronolog/usr/local/sbin/cronolog[root@localhostcronolog-1.6.2]#

用which cronolog可以查到安装的路径,这个路径待会在修改catalina.sh时会用到。

修改catalina.sh 将183行修改成184行内容,注释掉355行,368、369行替换成370、371行,379、380行替换成381、382行;

[root@localhostcronolog-1.6.2]#cp/usr/local/tomcat/bin/catalina.sh/usr/local/tomcat/bin/catalina.shbak[root@localhostcronolog-1.6.2]#vim/usr/local/tomcat/bin/catalina.sh182if[-z $CATALINA_OUT ];then183#CATALINA_OUT= $CATALINA_BASE /logs/catalina.out184CATALINA_OUT= $CATALINA_BASE /logs/catalina.%Y-%m-%d.out185fi......355#touch $CATALINA_OUT ......363-Djava.security.manager\364-Djava.security.policy== $CATALINA_BASE /conf/catalina.policy\365-Dcatalina.base= $CATALINA_BASE \366-Dcatalina.home= $CATALINA_HOME \367-Djava.io.tmpdir= $CATALINA_TMPDIR \368#org.apache.catalina.startup.Bootstrap $@ start\369#  $CATALINA_OUT 2 1 370org.apache.catalina.startup.Bootstrap $@ start2 1\371|/usr/local/sbin/cronolog $CATALINA_OUT  /dev/null 372373else374 $_RUNJAVA  $LOGGING_CONFIG $LOGGING_MANAGER$JAVA_OPTS$CATALINA_OPTS\375-Djava.endorsed.dirs= $JAVA_ENDORSED_DIRS -classpath $CLASSPATH \376-Dcatalina.base= $CATALINA_BASE \377-Dcatalina.home= $CATALINA_HOME \378-Djava.io.tmpdir= $CATALINA_TMPDIR \379#org.apache.catalina.startup.Bootstrap $@ start\380#  $CATALINA_OUT 2 1 381org.apache.catalina.startup.Bootstrap $@ start2 1\382|/usr/local/sbin/cronolog $CATALINA_OUT  /dev/null 383384fi[root@localhostbin]#./catalina.shstartUsingCATALINA_BASE:/app/apache-tomcat-7.0.61UsingCATALINA_HOME:/app/apache-tomcat-7.0.61UsingCATALINA_TMPDIR:/app/apache-tomcat-7.0.61/tempUsingJRE_HOME:/app/jdk1.7.0_79UsingCLASSPATH:/app/apache-tomcat-7.0.61/bin/bootstrap.jar:/app/apache-tomcat-7.0.61/bin/tomcat-juli.jarTomcatstarted.[root@localhostbin]#servicetomcatstop[root@localhostbin]#servicetomcatstart

可以通过./catalina.sh start 来查看配置文件是否正确;这样在/usr/local/tomcat/logs每天会自动生成catalina.%Y-%m-%d.out文件,如果有报错去掉前面的空格试试,下面我们要做的是定期清理这些过期的文件,我们可以通过crontab来实现

[root@localhostlogs]#crontab-enocrontabforroot-usinganemptyonecrontab:installingnewcrontab[root@localhostlogs]#crontab-l305**6/bin/find/usr/local/tomcat/logs/-mtime+7-typef-name catalina.*.out -exec/bin/rm-f{}\;[root@localhostlogs]#cat/var/spool/cron/root305**6/bin/find/usr/local/tomcat/logs/-mtime+7-typef-name catalina.*.out -exec/bin/rm-f{}\;[root@localhostlogs]#

日期格式串:

%a本地简短星期名(e.g.:Sun..Sat)%A本地完整星期名(e.g.:Sunday..Saturday)%b本地简短月名(e.g.:Jan..Dec)%B本地完整月名(e.g.:January..December)%c本地日期与时间(e.g.:“SunDec1514:12:47GMT1996″)%d一月中的第几日(01..31)%j一年中的第几天(001..366)%m月名的数字表示(01..12)%U一年中以星期日为每周第一天计算的星期数(00..53,第一周包括新年的第一个星期日)%W一年中以星期一为每周第一天计算的星期数(00..53,第一周包括新年的第一个星期一)%w星期名的数字表示(0..6,0为星期日)%x本地日期(e.g.今天在北京是:“15/12/96″)%y不带世纪的年(00..99)%Y带世纪的年(1970..2038)

时间格式串:

%H24小时制小时(00..23)%I12小时制小时(01..12)%p本地AM/PM指示符%M分钟(00..59)%S秒(00..61)%X本地时间(e.g.:“15:12:47″)%Z时区(e.g.GMT),如果不能检测出时区,值为空

特殊格式串:

%%%字符%n新行%ttab字符

积极思考造成积极人生,消极思考造成消极人生。

Linux下定时切割Tomcat日志并删除指定天数前的日志记录推荐

相关文章:

你感兴趣的文章:

标签云: