详解关于tomcat切割catalina.out日志的三种方式
1.log4j进行日志切分
1)准备三个包:log4j-1.2.17.jar tomcat-juli.jar tomcat-juli-adapters.jar 放到tomcat的lib目录或者是工程的web_inf/lib下,
2)在lib目录下新建log4j.properties,加入以下内容
log4j.rootlogger = info, catalina # define all the appenders log4j.appender.catalina = org.apache.log4j.dailyrollingfileappender log4j.appender.catalina.file = ${catalina.base}/logs/catalina log4j.appender.catalina.append = true log4j.appender.catalina.encoding = utf-8 # roll-over the log once per day log4j.appender.catalina.datepattern = '.'yyyy-mm-dd'.log' log4j.appender.catalina.layout = org.apache.log4j.patternlayout log4j.appender.catalina.layout.conversionpattern = %d [%t] %-5p %c- %m%n log4j.appender.localhost = org.apache.log4j.dailyrollingfileappender log4j.appender.localhost.file = ${catalina.base}/logs/localhost log4j.appender.localhost.append = true log4j.appender.localhost.encoding = utf-8 log4j.appender.localhost.datepattern = '.'yyyy-mm-dd'.log' log4j.appender.localhost.layout = org.apache.log4j.patternlayout log4j.appender.localhost.layout.conversionpattern = %d [%t] %-5p %c- %m%n log4j.appender.manager = org.apache.log4j.dailyrollingfileappender log4j.appender.manager.file = ${catalina.base}/logs/manager log4j.appender.manager.append = true log4j.appender.manager.encoding = utf-8 log4j.appender.manager.datepattern = '.'yyyy-mm-dd'.log' log4j.appender.manager.layout = org.apache.log4j.patternlayout log4j.appender.manager.layout.conversionpattern = %d [%t] %-5p %c- %m%n log4j.appender.host-manager = org.apache.log4j.dailyrollingfileappender log4j.appender.host-manager.file = ${catalina.base}/logs/host-manager log4j.appender.host-manager.append = true log4j.appender.host-manager.encoding = utf-8 log4j.appender.host-manager.datepattern = '.'yyyy-mm-dd'.log' log4j.appender.host-manager.layout = org.apache.log4j.patternlayout log4j.appender.host-manager.layout.conversionpattern = %d [%t] %-5p %c- %m%n log4j.appender.console = org.apache.log4j.consoleappender log4j.appender.console.encoding = utf-8 log4j.appender.console.layout = org.apache.log4j.patternlayout log4j.appender.console.layout.conversionpattern = %d [%t] %-5p %c- %m%n # configure which loggers log to which appenders log4j.logger.org.apache.catalina.core.containerbase.[catalina].[localhost] = info, localhost log4j.logger.org.apache.catalina.core.containerbase.[catalina].[localhost].[/manager] =\ info, manager log4j.logger.org.apache.catalina.core.containerbase.[catalina].[localhost].[/host-manager] =\ info, host-manager
3)再tomcat根目录下,conf文件夹下,删除或者重命名logging.properties文件。然后修改context.xml文件,在<context> 标签修改为<context swallowoutput="true">,以接管tomcat的日志输出。这样,使用log4j进行日志切分就完成了。
2、使用cronolog进行切分日志
cronolog是一个过滤器程序,它从标准输入读取日志文件条目,并将每个条目写入由文件名模板和当前日志所指定的输出文件中。 当扩展文件名改变时,关闭当前文件,并打开一个新文件。 cronolog是为了与apache等web服务器一起使用,将访问日志分为每日或每月日志。
# wget https://files.cnblogs.com/files/crazyzero/cronolog-1.6.2.tar.gz # tar -zxf cronolog-1.6.2.tar.gz # cd cronolog # ./configure # make && make install
# which cronolog # /usr/local/sbin/cronolog
编辑tomcat下的bin/catalina.sh(注:行数不一定是我这个,找到语句为主)
将以上两处内容替换为:
org.apache.catalina.startup.bootstrap "$@" start \ 2>&1 |/usr/local/sbin/cronolog "$catalina_base/logs/catalina-%y-%m-%d.out" &
完成后,重新启动tomcat即可。
3、使用logrotate进行切割。
在/etc/logrotate.d下,新建tomcatrotate,编辑tomatrotate,写入如下内容:
/usr/local/tomcat7.0.79/logs/catalina.out { daily rotate 15 missingok dateext compress notifempty copytruncate }
daily 指定转储周期为每天
rotate 15 指定日志文件删除之前转储的次数,0指没有备份,5指保留5个备份
missingok 如果日志不存在则忽略该警告信息
dateext 文件后缀是日期格式,也就是切割后文件是:xxx.log-20150828.gz
compress 通过gzip压缩转储以后的日志(gzip -d xxx.gz解压)
notifempty 如果是空文件的话,不转储
copytruncate 用于还在打开中的日志文件,把当前日志备份并截断
/usr/local/tomcat7.0.79/logs/catalina.out 指定catalina.out的路径
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
下一篇: css的基础用法(下)