我的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

10-08 07:06