springboot日志集成Logback


java有许多的日志组件,比如 log4j,log4j2,logback还有java自生提供的Java Util Logging,其实在springboot中对这些组件都提供了支持,log4j,log4j2和logback都提供相应的组件支持。

一、Logback

在springboot中默认使用的日志工具是logback,不过在提及具体的日志工具之前要提一个名词,这个名词就是slf4j简单日志门面(Simple Logging Facade For Java)

百度百科解释https://baike.baidu.com/item/slf4j/6408868

slf4j不是具体的日志解决方案,它有点类似于jdbc,使用了门面模式,是一个针对各类日志的抽象实现,既然是抽象的日志实现,在springboot中肯定不需要额外导入。

注意:spring-boot-starter中就提供了对spring-boot-starter-logging的依赖在spring-boot-starter-logging中可以看到以及集成了slf4j与具体实现logback的默认支持
在这里插入图片描述

二、编辑controller

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
private final Logger logger=LoggerFactory.getLogger(UserController.class);

在这里插入图片描述
在浏览器上输入:localhost:8080/hello,可以看控制台日志的输出
在这里插入图片描述

三、日志级别的控制

默认情况下,Spring Boot 配置的是INFO 日志级别,也就是会输出INFO级别以上的日志(ERROR, WARN, INFO)。

  1. 如果需要 Debug 级别的日志。在src/main/resources/application.properties 中配置debug=true
  2. 配置 logging.level.* 来具体输出哪些包的日志级别。
    例如:
    logging.level.root=INFO
    #除了以下的包是debug,其他所有文件都是info级别
    logging.level.org.springframework.web=DEBUG
    logging.level.cn.enjoy.controller=DEBUG
    在这里插入图片描述

四、日志文件

一般情况下,springboot日志只会输出到控制台,并不会写入到日志文件,但是,在一些正式环境的应用中,我们需要通过在 application.properites 文件中配置 logging.file 文件名称和 logging.path 文件路径,将日志输出到日志文件中。

logging.path = /var/tmp
logging.file = xxx.log
logging.level.root = info

注意: 如果只配置 logging.path,在 /var/tmp文件夹生成一个日志文件为 spring.log。如果只配置 logging.file,会在项目的当前路径下生成一个 xxx.log 日志文件。

这里有一个坑,logging.path 和logging.file都配置了,只会有logging.file生效,所以,如果要指定日志生成的具体位置使用logging.file 配置就好

在application.properties中配置logging.file =F:\log\enjoy.log

在这里插入图片描述
这样在F盘的相应位置出现日志文件

猜你喜欢

转载自blog.csdn.net/GanYangBa/article/details/109226473