这种问题一般都是第三方依赖的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>总结:出现这种问题,那有很大概率都是日志框架冲突了,只要你顺着这个思路解决,那一般都是可以解决的