Не могу найти logback.xml в папке ресурсов

Я пытаюсь использовать 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 папка:

образец дерева

| - pom.xml
`- SRC
    `- главная
        | - Ява
        |  
        | - ресурсы
        |   `- logback.xml
     

и моя структура проекта:

2 ответа

Решение

Если вы внимательно прочитаете предоставленное сообщение об ошибке, вы заметите, что ваша проблема заключается в множественных привязках 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:

Если вы хотите использовать logback-classic в качестве базового каркаса ведения журналов, все, что вам нужно сделать, это объявить ch.qos.logback: logback-classic в качестве зависимости в вашем файле 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.

Используете ли вы 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

Другие вопросы по тегам