簡體   English   中英

在資源文件夾中找不到logback.xml

[英]Can not find logback.xml in resources folder

我正在嘗試在項目中使用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

我的項目結構是:

在此處輸入圖片說明

如果您仔細閱讀提供的錯誤消息,您會注意到問題是構建路徑上sfl4j的多個綁定。 您包括了sfl4j-log4j和經典的logback工件。 由於logback-classic已經包含sfl4j的本機實現,並且還自動將sfl4j jar添加到您的項目中,因此最終在構建路徑中包含多個sf4j。 只需下定決心,僅選擇一個日志記錄框架,然后從依賴項中刪除另一個。

因此,如果選擇經典的logback,則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手冊

如果希望將logback-classic用作基礎日志記錄框架,則只需在pom.xml文件中將“ ch.qos.logback:logback-classic”聲明為依賴項即可,如下所示。 除了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的“最近定義”依賴關系中介規則來強加正確版本的工件。

您是否正在使用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

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM