Отключить Logback в SpringBoot

Похоже, Springboot самонастраивается для использования Logback с Tomcat. Я хотел бы отключить это и использовать тот, который я предоставляю в моем classpath.

Сообщение об ошибке ниже.

LoggerFactory не является LogbackContext Logback, но Logback находится на пути к классам. Удалите Logback или конкурирующую реализацию (класс org.slf4j.impl.SimpleLoggerFactory). Объект класса [org.slf4j.impl.SimpleLoggerFactory] должен быть экземпляром класса ch.qos.logback.classic.LoggerContext.

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <artifactId>spring-boot-starter-parent</artifactId>
        <groupId>org.springframework.boot</groupId>
        <version>1.0.1.RELEASE</version>
    </parent>

    <groupId>com.fe</groupId>
    <artifactId>cloudapp</artifactId>
    <version>1.0.0</version>
    <name>Withinet-PaaS</name>
    <description>Develop your web applications in on our infrastructure and we will worry about administration and scalability of your app.</description>

    <properties>
        <java.version>1.7</java.version>
        <guava.version>16.0.1</guava.version>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
    </properties>

    <dependencies>
    <dependency>
        <groupId>com.sun.jersey</groupId>
        <artifactId>jersey-client</artifactId>
        <version>1.8</version>
    </dependency>
        <dependency>
        <groupId>com.withinet.cloudapp</groupId>
    <artifactId>slave</artifactId>
    <version>1.0.0</version>    
        </dependency>
        <dependency>
            <groupId>org.apache.wicket</groupId>
            <artifactId>wicket-core</artifactId>
            <version>6.15.0</version>
        </dependency>
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-core</artifactId>
            <version>4.3.0.Final</version>
        </dependency>

        <dependency>
            <groupId>com.google.code.gson</groupId>
            <artifactId>gson</artifactId>
            <version>2.2.4</version>
        </dependency>

        <!-- Spring Boot -->

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <!-- Hibernate validator -->

        <dependency>
            <groupId>javax.validation</groupId>
            <artifactId>validation-api</artifactId>
            <version>1.1.0.Final</version>


        </dependency>
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-validator-annotation-processor</artifactId>
            <version>4.1.0.Final</version>
        </dependency>

        <!-- Guava -->

        <dependency>
            <groupId>com.google.guava</groupId>
            <artifactId>guava</artifactId>
            <version>${guava.version}</version>
        </dependency>

        <!-- Java EE -->

        <dependency>
            <groupId>javax.inject</groupId>
            <artifactId>javax.inject</artifactId>
            <version>1</version>
        </dependency>

        <!--  Search -->
        <dependency>
            <groupId>org.apache.lucene</groupId>
            <artifactId>lucene-queryparser</artifactId>
            <version>4.8.0</version>
        </dependency>

        <!--  Security 
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-security</artifactId>
        </dependency>-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-tomcat</artifactId>
            <scope>provided</scope>
        </dependency>
    </dependencies>

    <build>

        <plugins>

            <!-- Spring Boot Maven -->

            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <configuration>
                    <mainClass>com.withinet.cloud.Application</mainClass>
                    <layout>JAR</layout>
                </configuration>
                <executions>
                    <execution>
                        <goals>
                            <goal>repackage</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>

        </plugins>
    </build>
</project>

23 ответа

Решение

Для разрешения конфликта добавьте исключение как в spring-boot-starter, так и в spring-boot-starter-web.

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter</artifactId>
  <exclusions>
    <exclusion>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-logging</artifactId>
    </exclusion>
  </exclusions>
</dependency>

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-web</artifactId>
  <exclusions>
    <exclusion>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-logging</artifactId>
    </exclusion>
  </exclusions>
</dependency>

Чтобы добавить лучшее, более общее решение в Gradle (все экземпляры будут исключены):

configurations {
    all*.exclude module : 'spring-boot-starter-logging'
}

С https://docs.gradle.org/current/userguide/dependency_management.html

Добавить решение в Gradle.

dependencies {
    compile ('org.springframework.boot:spring-boot-starter') {
        exclude module : 'spring-boot-starter-logging'
    }
    compile ('org.springframework.boot:spring-boot-starter-web') {
        exclude module : 'spring-boot-starter-logging'
    }
}

Правильный способ исключить ведение журнала по умолчанию и настроить log4j для ведения журнала.

<dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter</artifactId>
 <exclusions>
     <exclusion>
     <groupId>org.springframework.boot</groupId>
     <artifactId>spring-boot-starter-logging</artifactId>
     </exclusion>
 </exclusions>
</dependency>

См. Spring Logging - Как сделать.

Я обнаружил, что за исключением полного spring-boot-starter-logging модуль не нужен. Все, что нужно, это исключить org.slf4j:slf4j-log4j12 модуль.

Добавление этого в файл сборки Gradle решит проблему:

configurations {
    runtime.exclude group: "org.slf4j", module: "slf4j-log4j12"
    compile.exclude group: "org.slf4j", module: "slf4j-log4j12"
}

Смотрите этот другой ответ Stackru для более подробной информации.

Для градла,

Вы можете увидеть это решение по адресу: http://www.idanfridman.com/how-to-exclude-libraries-from-dependcies-using-gradle/

Просто нужно добавить exclude в configurations:

configurations {
    providedRuntime
    compile.exclude(group: 'ch.qos.logback')
}

Я делаю это, чтобы решить мою проблему

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-log4j</artifactId>
    <exclusions>
        <exclusion>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-log4j12</artifactId>
        </exclusion>
    </exclusions>
</dependency>

Найдите spring-boot-starter-test в вашем pom.xml и измените его следующим образом:

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <exclusions>
            <exclusion>
                <artifactId>commons-logging</artifactId>
                <groupId>commons-logging</groupId>
            </exclusion>
        </exclusions>
        <scope>test</scope>
    </dependency>

Исправлена ​​ошибка вроде:

Причина : java.lang.IllegalArgumentException: LoggerFactory не является LogbackContext, но Logback находится на пути к классам.

Либо удалите Logback или конкурирующую реализацию

(класс org.apache.logging.slf4j.Log4jLoggerFactory загружен из файла: $ {M2_HOME} /repository/org/apache/logging/log4j/log4j-slf4j-impl/2.6.2/log4j-slf4j-impl-2.6.2. баночка).

Если вы используете WebLogic, вам нужно добавить 'org.slf4j' для предпочтения пакетов приложений в WEB-INF / weblogic.xml: org.apache.logging.slf4j.Log4jLoggerFactory

Это может помочь, если вы скажете, какой именно предпочитаемый вами регистратор, и что вы сделали, чтобы попробовать и установить его. В любом случае, Spring Boot пытается работать с тем, что находится в пути к классам, поэтому, если вы не хотите входить в систему, удалите его из пути к классам. В документации есть инструкции для log4j, но то же самое относится и к другим поддерживаемым системам журналирования (что угодно, slf4j, log4j или java util).

У меня такая же проблема.

Если вы используете log4j2

В весеннем сапоге 2.4.0

Я разрешаю ниже,

       <dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter</artifactId>
    <exclusions>
        <exclusion>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-logging</artifactId>
        </exclusion>
    </exclusions>
</dependency>

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-log4j2</artifactId>
    <exclusions>
        <exclusion>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-slf4j-impl</artifactId> <-- exclude this artifactId
        </exclusion>
    </exclusions>
</dependency>

После, Maven Build > Clean > Run

Работай на меня.

Следующие работы для меня

<dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter</artifactId>
        <exclusions>
            <exclusion>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-logging</artifactId>
            </exclusion>
        </exclusions>
    </dependency>

Я решил мою проблему через это ниже:

compile('org.mybatis.spring.boot:mybatis-spring-boot-starter:1.3.0'){
    exclude module: 'log4j-slf4j-impl'
    exclude module: 'logback-classic'
}
compile('org.springframework.boot:spring-boot-starter-web'){
    exclude module: 'log4j-slf4j-impl'
    exclude module: 'logback-classic'
}

В моем случае требовалось только исключить spring-boot-starter-logging артефакт из spring-boot-starter-security один.

Это во вновь созданном проекте Spring boot 2.2.6.RELEASE, включая следующие зависимости:

  • пружина-загрузчик-стартер-безопасность
  • весенняя загрузка-стартер-проверка
  • весна-загрузка-стартер-сеть
  • весенний пусковой тест

Я узнал бегая mvn dependency:tree и ищу ch.qos.logback.

Связанные с весенним ботинком <dependencies> в моем pom.xml выглядит так:

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-security</artifactId>
        <exclusions>
            <exclusion>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-logging</artifactId>
            </exclusion>
        </exclusions>           
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-log4j2</artifactId>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-validation</artifactId>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-devtools</artifactId>
        <scope>runtime</scope>
        <optional>true</optional>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-configuration-processor</artifactId>
        <optional>true</optional>
    </dependency>

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
        <exclusions>
            <exclusion>
                <groupId>org.junit.vintage</groupId>
                <artifactId>junit-vintage-engine</artifactId>
            </exclusion>
        </exclusions>
    </dependency>

    <dependency>
        <groupId>org.springframework.security</groupId>
        <artifactId>spring-security-test</artifactId>
        <scope>test</scope>
    </dependency>



</dependencies>

Это сработало для меня просто отлично

configurations {
    all*.exclude module : 'spring-boot-starter-logging'
}

Но это не сработает для пользователей Maven. Все мои зависимости были в libs.gradle, и я не хотел, чтобы они были в других файлах. Так что эта проблема была решена путем добавления exclude module : 'spring-boot-starter-logging в spring-boot-starter-data-jpa, spring-boot-starter-test и практически во всем с загрузочным словом.

ОБНОВИТЬ

Оказывается, мой новый проект нуждается в обновлении spring-boot-starter-test 1,5 и старше не было spring-boot-starter-logging, 2.0 имеет это

Добавьте это в свой build.gradle

configurations.all {
    exclude group: 'org.springframework.boot', module: 'spring-boot-starter-tomcat'
    exclude group: 'org.springframework.boot', module: 'spring-boot-starter-logging'
    exclude group: 'org.springframework.boot', module: 'logback-classic'
}

Используя Gradle & Lombok, вот самая простая конфигурация для Log4j2 , которая работала для меня с использованием последней версии Spring Boot (на данный момент 2.4.1):

build.gradle (частично)

      configurations {
    compileOnly { extendsFrom annotationProcessor }
    compile.exclude module: 'spring-boot-starter-logging'
}


dependencies {
    implementation 'org.springframework.boot:spring-boot-starter-web'
    implementation 'org.springframework.boot:spring-boot-starter-security' 
    implementation 'org.springframework.boot:spring-boot-starter-web-services'
    implementation 'org.springframework.boot:spring-boot-starter-log4j2'

    compileOnly 'org.projectlombok:lombok'

    // (*** other dependencies ***)

    annotationProcessor 'org.projectlombok:lombok'
    testImplementation 'org.springframework.boot:spring-boot-starter-test'
    testImplementation 'org.springframework.security:spring-security-test'
}

Я заметил, что вы получите ошибки, если включите spring-bbot-starter-log4j2как compileOnlyзависимость, а не как implementation.

Просто аннотируйте свои классы с помощью @Log4j2(или же @Slf4j) и ломбок предоставит logпеременная, которую вы можете использовать для ведения журнала.

Как обычно, предоставьте log4j2.xmlфайл конфигурации в вашем /src/main/resourcesпапка.

Если эта ошибка произошла в SpringBoot, когда вы пытаетесь использовать log4j2, выполните следующие действия:

  • Удалите банку из упаковки, добавив это "excludeGroupIds log4j-slf4j-impl /excludeGroupIds"
  • Узнайте, какая библиотека зависит от "logback-classic", с помощью команды "mvn dependecy:tree"
  • Где бы вы ни находили, исключите его из зависимости.

Эта ошибка произошла, потому что logback переопределяет изменения log4j2. Поэтому, если вы хотите использовать log4j2, вы должны удалить библиотеку logback и ее зависимости.

Надеюсь, это кому-нибудь поможет.

В моем случае ниже работает исключение!!

    <dependency>
        <groupId>com.xyz.util</groupId>
        <artifactId>xyz-web-util</artifactId>
        <exclusions>
            <exclusion>
                <groupId>org.slf4j</groupId>
                <artifactId>slf4j-log4j12</artifactId>
            </exclusion>
        </exclusions>
    </dependency>

Отключить ведение журнала Spring Boot Starter

          <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
        <exclusions>                                               
            <exclusion>
                <groupId>org.springframework.boot</groupId>         
                <artifactId>spring-boot-starter-logging</artifactId> 
            </exclusion>
        </exclusions>
    </dependency>

Отключить LogBack ИЛИ Log4j из Spring Boot Starter

          <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
        <exclusions>                                  
            <exclusion>                                     
            <groupId>org.apache.logging.log4j</groupId>         
            <artifactId>log4j-to-slf4j</artifactId>             
            </exclusion>
    
            <exclusion>                                     
                <groupId>ch.qos.logback</groupId>               
                <artifactId>logback-classic</artifactId>     
            </exclusion>
        </exclusions>
    </dependency>

Просто добавьте конфигурацию logback.xml в ваш путь к классам и добавьте всю свою конфигурацию с добавлением root appender. Как только загрузка Spring завершит загрузку bean-компонента, он начнет запись в журнал в зависимости от вашей конфигурации.

Причина в том, что весенняя загрузка идет с логбэком в качестве конфигурации журнала по умолчанию, тогда как верблюд использует log4j. В этом причина конфликта. У вас есть два варианта: либо удалить возврат из весенней загрузки, как указано в ответах выше, либо удалить log4j из верблюда.

<dependency>
            <groupId>org.apache.camel</groupId>
            <artifactId>camel-spring-boot-starter</artifactId>
            <version>${camel.version}</version>
            <exclusions>
                <exclusion>
                    <groupId>org.slf4j</groupId>
                    <artifactId>slf4j-log4j12</artifactId>
                </exclusion>
            </exclusions>
        </dependency>

Мне было мало добавить исключения. Пришлось предоставить поддельную банку:

    <dependency>
        <groupId>ch.qos.logback</groupId>
        <artifactId>logback-classic</artifactId>
        <scope>system</scope>
        <systemPath>${project.basedir}/empty.jar</systemPath>
    </dependency>

Чтобы добавить исключение для выхода из среды IDE Netbeans

  1. Откройте раздел> Projects Explorer для вашего проекта
  2. Перейдите к> Зависимости, как показано ниже
  3. Трассировка 'spring-boot-starter-logging-XXXjar'
  4. Щелкните правой кнопкой мыши по банке и выберите " Исключить зависимость", как показано ниже. Это исключает jar logback для pom.xml следующим образом;

      <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
        <exclusions>
            <exclusion>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-logging</artifactId>
            </exclusion>
        </exclusions>
    </dependency>
    

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