在资源文件夹中找不到logback.xml

时间:2014-05-03 10:51:09

标签: java logging slf4j logback

我试图在我的项目中使用logback但是有一些问题。当我运行我的代码时,它给了我这个:

SLF4J: Class path contains multiple SLF4J bindings.
SLF4J: Found binding in [jar:file:/home/mostafa/.m2/repository/org/slf4j/slf4j-log4j12/1.7.2/slf4j-log4j12-1.7.2.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: Found binding in [jar:file:/home/mostafa/.m2/repository/ch/qos/logback/logback-classic/1.1.1/logback-classic-1.1.1.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: See http://www.slf4j.org/codes.html#multiple_bindings for an explanation.
SLF4J: Actual binding is of type [org.slf4j.impl.Log4jLoggerFactory]
log4j:WARN No appenders could be found for logger (com.project.Test).
log4j:WARN Please initialize the log4j system properly.
log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.

我的logback.xml位于resources文件夹:

$ tree sample

|-- pom.xml
`-- src
    `-- main
        |-- java
        |  
        |-- resources
        |   `-- logback.xml
     

我的项目结构是:

enter image description here

2 个答案:

答案 0 :(得分:3)

如果仔细阅读提供的错误消息,您会发现问题是构建路径上sfl4j的多个绑定。您包括sfl4j-log4j和logback-classic工件。由于logback-classic已经包含sfl4j的本机实现,并且还自动将sfl4j jar添加到您的项目中,因此您最终会在构建路径中拥有多个sf4j。只需下定决心,只选择一个日志框架,并从依赖项中删除另一个日志框架。

因此,如果您选择logback-classic,您的Maven依赖项将如下所示:

<dependency> 
  <groupId>ch.qos.logback</groupId>
  <artifactId>logback-classic</artifactId>
  <version>1.1.1</version>
</dependency>

如果你选择log4j,那就让它看起来像这样

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

但不要包括两者!

来自sfl4j manual

  

如果您希望使用logback-classic作为基础日志记录   框架,你需要做的就是声明   &#34; ch.qos.logback:的logback经典&#34;作为pom.xml文件中的依赖项   如下所示。除了logback-classic-1.0.13.jar之外,这将是   拉slf4j-api-1.7.7.jar以及logback-core-1.0.13.jar到你的   项目。请注意,明确声明依赖关系   logback-core-1.0.13或slf4j-api-1.7.7.jar没有错,可能是   必须通过强制实施所述工件的正确版本   Maven&#34;最接近的定义&#34;依赖调解规则

答案 1 :(得分:1)

您是否正在使用cassandra或其他任何可能将log4j工件添加到您的库中的文件?

如果你将cassandra-all工件添加到依赖项中,并且由于cassandra使用log4j作为SLF4J后端进行自我记录,它会导入slf4j-log4j12.jar

您可以像这样编辑pom.xml:

    <dependency>
        <groupId>org.apache.cassandra</groupId>
        <artifactId>cassandra-all</artifactId>
        <version>2.0.5</version>
        <exclusions>
            <exclusion>
                <groupId>org.slf4j</groupId>
                <artifactId>slf4j-log4j12</artifactId>
            </exclusion>
            <exclusion>
                <groupId>log4j</groupId>
                <artifactId>log4j</artifactId>
            </exclusion>
        </exclusions>
    </dependency>

还阅读以下链接:

http://www.slf4j.org/codes.html#multiple_bindings