我的tomcat web应用程序有以下log4j.xml
文件:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE log4j:configuration PUBLIC "-//APACHE//DTD LOG4J 1.2//EN" "log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
<!-- Appenders -->
<appender name="console" class="org.apache.log4j.ConsoleAppender">
<param name="Target" value="System.out" />
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern"
value="%-5p: %d{ABSOLUTE} [%t] %c:%L - %m%n" />
</layout>
</appender>
<appender name="errorFileAppender" class="org.apache.log4j.RollingFileAppender">
<param name="threshold" value="error" />
<rollingPolicy class="org.apache.log4j.rolling.TimeBasedRollingPolicy">
<param name="FileNamePattern"
value="${catalina.base}/logs/error.%d{yyyy-MM-dd_HH}.log"/>
<param name="ActiveFileName" value="${catalina.base}/logs/error.log"/>
</rollingPolicy>
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern"
value="%-5p: %d{ABSOLUTE} [%t] %c:%L - %m%n" />
</layout>
</appender>
<!-- Application Loggers -->
<!-- some loggers -->
<!-- Root Logger -->
<root>
<priority value="warn" />
<appender-ref ref="console" />
<appender-ref ref="errorFileAppender" />
</root>
</log4j:configuration>
使用此配置,所有内容都会记录到catalina.out
但我的目的也是将所有错误记录为单独error.log
,每小时滚动一次
当我使用FileAppender
error.log
文件时,会创建并填充错误日志。但是,当我切换到RollingFileAppender
error.log
时,文件甚至都没有创建。
请帮我这个配置。我不能在这里发现错误。
答案 0 :(得分:0)
错误是,我使用了org.apache.log4j.RollingFileAppender
而不是org.apache.log4j.rolling.RollingFileAppender