Отключить 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-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
- Откройте раздел> Projects Explorer для вашего проекта
- Перейдите к> Зависимости, как показано ниже
- Трассировка 'spring-boot-starter-logging-XXXjar'
Щелкните правой кнопкой мыши по банке и выберите " Исключить зависимость", как показано ниже. Это исключает 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>