看来Springboot自动配置使用Logback和Tomcat。我想禁用它并使用我在类路径中提供的那个。
以下错误消息。
LoggerFactory不是Logback LoggerContext,而是Logback 类路径。删除Logback或竞争实现 (class 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>
答案 0 :(得分:108)
在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>
答案 1 :(得分:45)
在Gradle中添加更好,更通用的解决方案(将排除所有实例):
configurations {
all*.exclude module : 'spring-boot-starter-logging'
}
来自https://docs.gradle.org/current/userguide/dependency_management.html
答案 2 :(得分:35)
在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'
}
}
答案 3 :(得分:10)
我喜欢这样来解决我的问题
<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>
答案 4 :(得分:7)
对于gradle,
您可以在http://www.idanfridman.com/how-to-exclude-libraries-from-dependcies-using-gradle/
看到此解决方案只需在exclude
中添加configurations
:
configurations {
providedRuntime
compile.exclude(group: 'ch.qos.logback')
}
答案 5 :(得分:6)
我发现不需要排除完整的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"
}
有关详细信息,请参阅此其他StackOverflow answer。
答案 6 :(得分:5)
以下对我有用的
<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>
答案 7 :(得分:5)
在我的情况下,只需要从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>
答案 8 :(得分:5)
在pom.xml中找到spring-boot-starter-test并按如下所示进行修改:
<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 不是 Logback LoggerContext ,但 Logback 已启用classpath。
删除 Logback 或竞争实施
( class org.apache.logging.slf4j.Log4jLoggerFactory 从文件加载: $ {M2_HOME} /repository/org/apache/logging/log4j/log4j-slf4j-impl/2.6.2/log4j-slf4j-impl-2.6.2.jar )。< / p>
如果您使用的是WebLogic,则需要在WEB-INF / weblogic.xml中的prefer-application-packages中添加'org.slf4j': org.apache.logging.slf4j .Log4jLoggerFactory 强>
答案 9 :(得分:4)
我通过以下方式解决了我的问题:
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'
}
答案 10 :(得分:3)
如果您说出您的首选记录器完全正确,以及您尝试安装它所做的工作,这可能会有所帮助。无论如何,Spring Boot尝试使用类路径中的任何内容,因此如果您不想要回溯,请将其从类路径中删除。有关log4j in the docs的说明,但同样的事情适用于其他受支持的日志记录系统(任何slf4j,log4j或java util)。
答案 11 :(得分:3)
这对我来说很好
Users
但是对于 maven 用户而言,它是行不通的。我所有的依赖项都在libs.gradle中,我不希望它们在其他文件中。因此,通过在configurations {
all*.exclude module : 'spring-boot-starter-logging'
}
,exclude module : 'spring-boot-starter-logging
以及几乎所有带有引导字的内容中添加spring-boot-starter-data-jpa
来解决了这个问题。
更新
我的新项目需要更新,事实证明spring-boot-starter-test
为1.5,而较旧的项目则没有spring-boot-starter-test
。 2.0有它
答案 12 :(得分:3)
在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'
}
答案 13 :(得分:1)
如果在尝试使用log4j2时在SpringBoot中发生此错误,则 请执行以下步骤:
发生此错误是因为logback覆盖了log4j2的更改。因此,如果要使用log4j2,则必须删除logback库和依赖项。
希望这会对某人有所帮助。
答案 14 :(得分:0)
只需在类路径中添加logback.xml配置,并添加添加了root appender的所有配置。一旦Spring引导完成bean加载,它将根据您的配置开始记录。
答案 15 :(得分:0)
排除默认日志记录并配置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>
答案 16 :(得分:0)
要添加从Netbeans IDE登录的排除项
右键单击jar并选择 Exclude Dependency ,如下所示。这样排除了pom.xml上的logback jar;
<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>
答案 17 :(得分:0)
在我的情况下,以下排除方法有效!
<dependency>
<groupId>com.xyz.util</groupId>
<artifactId>xyz-web-util</artifactId>
<exclusions>
<exclusion>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
</exclusion>
</exclusions>
</dependency>
答案 18 :(得分:0)
添加排除条件对我来说还不够。我不得不提供一个假罐子:
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
<scope>system</scope>
<systemPath>${project.basedir}/empty.jar</systemPath>
</dependency>
答案 19 :(得分:0)
原因是,Spring Boot将logback作为其默认日志配置,而camel使用log4j。多数民众赞成在冲突的原因。您有两个选择,或者按照上述答案中的说明从spring boot中删除logback,或者从骆驼中删除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>
答案 20 :(得分:0)
对我来说同样的问题。
如果您使用的是log4j2
在Spring Boot 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构建>清理>运行
为我工作。
答案 21 :(得分:0)
使用 Gradle 和 Lombok,这是 Log4j2 的最简单配置,它使用最新的 Spring Boot(2.4.1 at这次):
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
)注释您的类,lombok 将提供可用于记录的 log
变量。
像往常一样,在您的 log4j2.xml
文件夹中提供一个 /src/main/resources
配置文件。