SpringBoot log4j日志没生成
从同事那接了一个脚手架,启动后发现日志文件没生成。
都知道SpringBoot默认带的logback,如果要用log4j需要把logback的依赖去掉。
看了下工程的pom.xml文件,确实是有加去掉spring-boot-starter-logging的声明。
1
2
3
4
5
6
|
< exclusions > < exclusion > < groupId >org.springframework.boot</ groupId > < artifactId >spring-boot-starter-logging</ artifactId > </ exclusion > </ exclusions > |
那怎么就死活不生成日志呢。
倒腾了好几次,无意中看到控制台最上面的输出:
SLF4J: Class path contains multiple SLF4J bindings.
SLF4J: Found binding in [jar:file:/D:/Users/xxx/.m2/repository/ch/qos/logback/logback-classic/1.1.11/logback-classic-1.1.11.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: Found binding in [jar:file:/D:/Users/xxx/.m2/repository/org/slf4j/slf4j-log4j12/1.7.25/slf4j-log4j12-1.7.25.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: See http://www.slf4j.org/codes.html#multiple_bindings for an explanation.
SLF4J: Actual binding is of type [ch.qos.logback.classic.util.ContextSelectorStaticBinder]
说的是SLF4J依赖冲突,然后最后用例logback的。摔,难怪log4j日志一直没生成。谷歌了一下,找到了解决办法。
修改pom.xml,加入以下代码把logback的依赖去掉。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
< dependency > < groupId >org.springframework.boot</ groupId > < artifactId >spring-boot-starter</ artifactId > < exclusions > < exclusion > < artifactId >logback-classic</ artifactId > < groupId >ch.qos.logback</ groupId > </ exclusion > < exclusion > < artifactId >log4j-over-slf4j</ artifactId > < groupId >org.slf4j</ groupId > </ exclusion > </ exclusions > </ dependency > |
spring boot启动失败不输出日志
spring boot启动失败,没有任何错误日志输出,只输出了如下信息:
可能的原因:
1、日志配置文件没有配好
解决:修改日志等级,找到logback-boot.xml文件,找到<root level="INFO"> </root>,修改日志等级,添加标准输出
1
2
3
|
< root level = "INFO" > < appender-ref ref = "STDOUT" /> </ root > |
如果自己没有写日志配置,可能是被其他jar包中的log配置文件覆盖了你本地的默认的日志。
解决办法:编写自己的日志配置文件或者排除一下资源文件。
2、jar冲突
3、idea本地缓存导致的失败
这个是我遇到的情况,莫名其妙,前一天晚上还好好的,第二天突然就启动不了,什么都不输出,还是只显示下面这图
此时可以尝试执行mvn clean命令,清除target目录下的之前打好的jar包或者是war包。
当然,也可以尝试这样,然后重新build。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/libertine1993/article/details/80857483