这种问题一般都是第三方依赖的log框架冲突,在pom文件中排除掉即可
例如:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<exclusions><!-- 去掉springboot默认配置 -->
<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</artifactId>
</dependency>
这里我不小心既引入了spring-boot-starter-web(已被我改成log4j2),又引入了spring-boot-starter(logback),导致日志框架冲突,当然我这里解决很简单,直接删除spring-boot-starter即可。
但是还有其他的比如说zookeeper这个包,他也是自带log框架的,如果和你自身项目冲突,也会报错。
全局处理:
当你使用maven多模块+springboot去构建项目时,可能这个模块需要依赖spring-boot-starter-data-redis,另一个又要依赖spring-boot-starter-mail,其实这些依赖包中都是存在log框架的,使用上面的办法的话,就要你一个一个去去除依赖,但是这里我们是明确知道我们在这个项目中要完全的把springboot本身的日志框架给去除,那么就可以使用全局去除依赖的方式,把spring-boot-starter-logging写成独立的dependency,然后用exclusion排除其中的所有依赖,就等于没有依赖spring-boot-starter-logging了::
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-logging</artifactId>
<exclusions>
<exclusion>
<groupId>*</groupId>
<artifactId>*</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-log4j2</artifactId>
</dependency>
总结:出现这种问题,那有很大概率都是日志框架冲突了,只要你顺着这个思路解决,那一般都是可以解决的