Log4J 2没有写入文件

时间:2017-02-04 20:40:30

标签: java logging log4j2

我正在尝试使用log4j实现一些日志记录2.控制台输出正常,但是当我尝试将一些日志写入文件时,我无法管理它。

我的pom.xml

<dependencies>
        <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-api</artifactId>
            <version>2.8</version>
        </dependency>
        <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-core</artifactId>
            <version>2.8</version>
        </dependency>
    </dependencies>

我的log4j2.xml

<?xml version="1.0" encoding="UTF-8"?>
<Configuration monitorInterval="60">
    <Properties>
        <Property name="log-path">logs</Property>
        <Property name="archive">${log-path}/archive</Property>
    </Properties>
    <Appenders>
        <Console name="Console-Appender" target="SYSTEM_OUT">
            <PatternLayout>
                <pattern>
                    [%-5level] %d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %c{1} - %msg%n
                </pattern>>
            </PatternLayout>
        </Console>
        <File name="File" fileName="${log-path}/xmlfilelog.log" immediateFlush="true" >
            <PatternLayout>
                <pattern>
                    [%-5level] %d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %c{1} - %msg%n
                </pattern>
            </PatternLayout>
        </File>
    </Appenders>
    <Loggers>
        <Logger name="les.dam" level="trace">
            <AppenderRef ref="File" level="trace"/>
        </Logger>
        <Root level="trace">
            <AppenderRef ref="Console-Appender"/>
        </Root>
    </Loggers>
</Configuration>

我以下列方式使用log4j:

private static Logger logger = LogManager.getLogger();
logger.debug("This is a debug message");
logger.info("This is an info message");
logger.warn("This is a warn message");
logger.error("This is an error message");
logger.fatal("This is a fatal message");

我使用记录器的类位于les.dam包。

xml配置在src / main / resources下。

logs文件夹与源文件夹处于同一级别。

2 个答案:

答案 0 :(得分:0)

您的配置看起来很好。一个可能的原因是找不到配置文件和默认配置(仅控制台的错误)。

要验证,请将配置更改为以<Configuration status="trace" monitorInterval="60">开头。这将打印内部log4j2调试日志记录到控制台。

您的log4j2.xml配置文件是否位于src/main/resources? - 更新:感谢更新,所以这是肯定的,这很好。

您可以先尝试使用绝对路径配置文件appender吗?

您能否显示进行日志记录的类的完整包名?

答案 1 :(得分:0)

您必须检查log4j2是否正在使用您提供的log4j2.xml,而不是默认配置。

  1. 更改log4j2.xml。
  2.   

    配置状态=&#34;跟踪&#34;则monitorinterval =&#34; 60&#34;

    然后检查控制台输出。

    1. 更改Console-Appender的PatternLayout。
    2.   

      %d {yyyy-MM-dd HH:mm:ss.SSS} [%-5level] [%t]%c {1} - %msg%n

      然后检查控制台输出。

      如果log4j使用log4j2.xml,请检查FileAppender配置 https://logging.apache.org/log4j/2.x/manual/appenders.html#FileAppender

      如果log4j没有使用log4j2.xml,https://logging.apache.org/log4j/2.x/manual/configuration.html。 -Dlog4j.configurationFile = SRC /主/资源/ log4j2.xml