log4j:WARN没有为记录器找到appender - 使用slf4j-log4j12

时间:2013-05-24 01:36:47

标签: java maven log4j slf4j

看起来好像已经多次询问过这个问题了。但是我尝试过的所有解决方案(主要是确保log4j.properties文件位于正确的位置并且输入正确)在我的情况下不起作用。

我有一个maven项目。我想使用log4j进行测试。测试类使用在src / main / java中定义的辅助方法,其中使用了记录器。

在我的助手类中(在src / main / java /中)我导入了

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

我已经实例化了记录器

private static final String TAG    = Helper.class.getSimpleName();
private static final Logger logger = LoggerFactory.getLogger(TAG);

我在src / main / resources和src / test / resources中都包含以下log4j.properties文件

### set log levels - for more verbose logging change 'info' to 'debug' ###
### Also add logfile to the root, if need stdout then add stdout appender here###
log4j.rootLogger=debug, stdout

### direct log messages to stdout ###
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{dd-mm HH:mm:ss,SSS} %p/%c{1}:%L - %m%n

在我的POM中,我已经包含了对slf4j的依赖

<dependency>
  <groupId>org.slf4j</groupId>
  <artifactId>slf4j-log4j12</artifactId>
</dependency>

在我的助手类的代码中,我以这种方式使用记录器

logger.debug("logger test...");

控制台中没有打印消息,我收到以下警告消息

log4j:WARN No appenders could be found for logger (Helper).
log4j:WARN Please initialize the log4j system properly.
log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.

我错过了什么?

更新

该问题与将log4j.configuration属性设置为log4j-test.xml的项目选项有关。我已经将以下插件添加到项目maven pom中,这解决了这个问题。

  <plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-surefire-plugin</artifactId>
    <version>2.14.1</version>
    <configuration>
      <systemPropertyVariables>
        <log4j.configuration>log4j.properties</log4j.configuration>
      </systemPropertyVariables>
    </configuration>
  </plugin>

2 个答案:

答案 0 :(得分:5)

从您发布的部分看起来没问题。让我们来研究一下这个问题吧。 我做了一个简单的项目(只有2个类Helper:有一个方法来调用你的logger语句,AppTest:一个JUnit测试来调用Helper中的方法)

  1. 清理生成的代码
    mvn clean
    存在以下文件
    ./src/main/java/sub/optimal/mavenexample/Helper.java
    ./的src /主/资源/ log4j.properties
    ./src/test/java/sub/optimal/mavenexample/AppTest.java
    ./的src /测试/资源/ log4j.properties

  2. 编译代码
    mvn编译
    存在以下文件
    ./src/main/java/sub/optimal/mavenexample/Helper.java
    ./src/main/resources/log4j.properties
    ./src/test/java/sub/optimal/mavenexample/AppTest.java
    ./src/test/resources/log4j.properties
    ./目标/类/ log4j.properties
    ./target/classes/sub/optimal/mavenexample/Helper.class

    如果未将属性文件复制到目标目录中,则需要找到原因

  3. 一些起点,检查

    的输出 mvn -debug编译
    mvn -Dlog4j.debug测试

答案 1 :(得分:0)

试试这些命令...

  

$ unset FLUME_HOME

然后尝试.....

它对我有用....