Похоже, Springboot автоматически настраивается для использования Logback с Tomcat. Я хотел бы отключить это и использовать тот, который я предоставляю в своем пути к классам.
Сообщение об ошибке ниже.
LoggerFactory не является Logback LoggerContext, но 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>
spring-boot
FOO
источник
источник
java.lang.ClassNotFoundException: org.apache.commons.logging.LogFactory
.Чтобы добавить лучшее, более общее решение в Gradle (все экземпляры будут исключены):
Из https://docs.gradle.org/current/userguide/dependency_management.html
источник
spring-boot-starter-logging
Добавить раствор в градиент.
источник
Я обнаружил, что исключать полный
spring-boot-starter-logging
модуль не нужно. Все, что нужно, - это исключитьorg.slf4j:slf4j-log4j12
модуль.Добавление этого в файл сборки Gradle решит проблему:
См. Этот другой ответ на StackOverflow для получения более подробной информации.
источник
Мне нравится это, чтобы решить мою проблему
источник
Для gradle,
Вы можете увидеть это решение по адресу: http://www.idanfridman.com/how-to-exclude-libraries-from-dependcies-using-gradle/
Просто нужно добавить
exclude
вconfigurations
:источник
Найдите в файле pom.xml spring-boot-starter-test и измените его следующим образом:
Исправлена ошибка вроде:
источник
Следующие работы для меня
источник
Может помочь, если вы скажете, какой именно регистратор вам больше нравится, и что вы сделали, чтобы попробовать и установить его. В любом случае Spring Boot пытается работать с тем, что находится в пути к классам, поэтому, если вы не хотите возвращаться, удалите его из пути к классам. Есть инструкции по log4j в документации , но то же самое будет применяться в другие поддерживаемые системы регистрации (ничего SLF4J, log4j или Java Util).
источник
Я решил свою проблему следующим образом:
источник
Это сработало для меня отлично
Но для пользователей 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 есть этоисточник
В моем случае требовалось только исключить
spring-boot-starter-logging
артефакт изspring-boot-starter-security
одного.Это во вновь созданном проекте Spring boot 2.2.6.RELEASE, включая следующие зависимости:
Я узнал, бегая
mvn dependency:tree
и ищаch.qos.logback
.Пружинный ботинок, описанный
<dependencies>
у меня,pom.xml
выглядит так:источник
Добавьте это в свой build.gradle
источник
Если эта ошибка возникла в SpringBoot, когда вы пытаетесь использовать log4j2, выполните следующие действия:
Эта ошибка возникла из-за того, что возврат при регистрации отменяет изменения log4j2. Итак, если вы хотите использовать log4j2, вам необходимо удалить библиотеку журнала и зависимости.
Надеюсь, это кому-то поможет.
источник
Правильный способ исключить ведение журнала по умолчанию и настроить log4j для ведения журнала.
Обратитесь к Spring Logging - How To .
источник
Чтобы добавить исключение для выхода из среды IDE Netbeans
Щелкните правой кнопкой мыши банку и выберите « Исключить зависимость», как показано ниже. Это исключает банку возврата в файл pom.xml следующим образом;
источник
В моем случае ниже работает исключение !!
источник
Мне было мало добавить исключения. Пришлось предоставить поддельную банку:
источник
Причина в том, что весенняя загрузка имеет логбэк в качестве конфигурации журнала по умолчанию, тогда как верблюд использует log4j. В этом причина конфликта. У вас есть два варианта: либо удалить возврат из весенней загрузки, как указано в ответах выше, либо удалить log4j из верблюда.
источник
Просто добавьте конфигурацию logback.xml в свой путь к классам и добавьте всю свою конфигурацию с добавленным корневым приложением. Как только загрузка Spring завершит загрузку bean-компонента, он начнет регистрацию в зависимости от вашей конфигурации.
источник