欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  网络运营

Tomcat使用Log4j输出catalina.out日志

程序员文章站 2022-06-27 19:07:05
tomcat默认的日志是用java.util.logging,有几点不足,文件catalian.out不能像log4j一样按天生成,将越来越大。日志格式和项目中用log4j...

tomcat默认的日志是用java.util.logging,有几点不足,文件catalian.out不能像log4j一样按天生成,将越来越大。日志格式和项目中用log4j打出来的不一致,不利于解析。

从tomcat官网()上找了下,修改一些配置、替换扩展包即可使用log4j输出catalian.out。

在$catalina_base/lib下创建log4j.properties文件

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.out
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
log4j.appender.catalina.layout = org.apache.log4j.patternlayout
#log4j.appender.catalina.layout.conversionpattern = %d [%t] %-5p %c- %m%n
log4j.appender.catalina.layout.conversionpattern =%d{yyyy-mm-dd hh:mm:ss.sss} %p [%t] %c | %m%n
# configure customed log to catalina.out
log4j.logger.com.xxxxx = warn, catalina
log4j.logger.org.apache = warn, catalina
log4j.logger.org.mybatis = warn, catalina
log4j.logger.java.sql = warn, catalina
log4j.logger.org.springframework = warn, catalina

更新tomcat相关jar包

下载log4j-1.2.17.jar()

下载tomcat7的2个jar包:tomcat-juli.jar 和 tomcat-juli-adapters.jar( 最好和tomcat版本对应)

把log4j-1.2.17.jar和tomcat-juli-adapters.jar放到$catalina_home/lib下;用新下载的tomcat-juli.jar包替换掉$catalina_home/bin/tomcat-juli.jar包。

删除$catalina_base/conf/logging.properties。

重启tomcat

关于默认的catalina日志格式

如果只想修改tomcat默认的日志格式,替换掉默认的java.util.logging.simpleformatter即可。simpleformatter类里format格式为loggingsupport.getsimpleformat(),它的具体值是:"%1$tb %1$td, %1$ty %1$tl:%1$tm:%1$ts %1$tp %2$s%n%4$s: %5$s%6$s%n",其中时间格式可能不是我们期望的,还有里面有个换行%n。比如想改为类似上面log4j的时间格式,可自己重写一个替换类(com.xxx.logformatter),format设为"%1$ty-%1$tm-%1$td %1$th:%1$tm:%1$ts.%1$tl %4$s %2$s %5$s%6$s%n"。修改$catalina_base/conf/logging.properties

java.util.logging.consolehandler.formatter = java.util.logging.simpleformatter

改为如下:

java.util.logging.consolehandler.formatter = com.xxx.logformatter
org.apache.juli.filehandler.formatter = com.xxx.logformatter

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。如果你想了解更多相关内容请查看下面相关链接