RollingFileAppender未创建日志文件

时间:2013-05-31 09:55:55

标签: tomcat configuration log4j configuration-files

我的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时,文件甚至都没有创建。

请帮我这个配置。我不能在这里发现错误。

1 个答案:

答案 0 :(得分:0)

错误是,我使用了org.apache.log4j.RollingFileAppender而不是org.apache.log4j.rolling.RollingFileAppender