我的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
时,甚至没有创建文件。请帮我这个配置。我不能在这里发现错误。
最佳答案
错误是,我使用了org.apache.log4j.RollingFileAppender
而不是org.apache.log4j.rolling.RollingFileAppender