温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

SpringBoot中 log4j日志未生成如何解决

发布时间:2021-07-27 17:54:26 来源:亿速云 阅读:549 作者:Leah 栏目:开发技术

SpringBoot中 log4j日志未生成如何解决,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

SpringBoot log4j日志没生成

从同事那接了一个脚手架,启动后发现日志文件没生成。

都知道SpringBoot默认带的logback,如果要用log4j需要把logback的依赖去掉。

看了下工程的pom.xml文件,确实是有加去掉spring-boot-starter-logging的声明。

<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的依赖去掉。

<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启动失败,没有任何错误日志输出,只输出了如下信息:

SpringBoot中 log4j日志未生成如何解决

可能的原因:

1、日志配置文件没有配好

解决:修改日志等级,找到logback-boot.xml文件,找到<root level="INFO"> </root>,修改日志等级,添加标准输出

<root level="INFO">
    <appender-ref ref="STDOUT"/>
</root>

如果自己没有写日志配置,可能是被其他jar包中的log配置文件覆盖了你本地的默认的日志。

解决办法:编写自己的日志配置文件或者排除一下资源文件。

2、jar冲突

3、idea本地缓存导致的失败

这个是我遇到的情况,莫名其妙,前一天晚上还好好的,第二天突然就启动不了,什么都不输出,还是只显示下面这图

SpringBoot中 log4j日志未生成如何解决

此时可以尝试执行mvn clean命令,清除target目录下的之前打好的jar包或者是war包。

当然,也可以尝试这样,然后重新build。

SpringBoot中 log4j日志未生成如何解决

看完上述内容,你们掌握SpringBoot中 log4j日志未生成如何解决的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI