Spring Boot的日志文件

2023-12-13 15:31:17

日志的作用

  1. 最主要的用途就是排除和定位问题
  2. 记录用户的登入状态,方便分析用户是正常登入还是恶意破解用户,如果同一个用户一段时间内多次登入,就可以对该IP进行拉黑处理
  3. 记录系统的操作日志,方便数据恢复和定位操作人
  4. 记录程序的执行时间,方便为以后优化程序提供数据支持

如何使用日志

@Controller
	@ResponseBody //表示返回的是数据而非页面
	@RequestMapping("/art")
	public class UserController {
		//1. 得到日志对象
		private static final Logger logger = LoggerFactory.getLogger(UserController.class);//参数表示该日志来自于哪个类
		@RequestMapping("/hi")
		public String sayHi() {
			//2. 写日志
			logger.trace("trace级别");
			logger.debug("debug级别");
			logger.info("info级别");
			logger.warn("warn级别");
			logger.error("error级别");
			return "hi";
		}
	}

注意:在得到日志对象时要导入的是slf4j的包
image.png
输出如下:
image.png
我们发现trace和debug级别的日志没有打印,这是因为系统默认的日志级别是info。

系统内置的日志框架

image.png
Spring Boot能输出控制台日志信息,说明Spring Boot内置了日志框架。日志框架的设计模式是“门面模式”,类似于一家餐厅,前台就是日志门面,后厨就是日志实现。客人来了有的要吃面有的要吃饭,如果没有前台,吃面的要找到煮面的师傅,要吃饭的要找到煮饭的师傅,而如果有前台服务员就不需要上面操作,直接告诉服务员,让他帮你找。回到代码中,有很多厂商提供了日志服务,如果开发者直接调用某个厂商的API,那么当这个厂商出现问题要使用其他厂商的服务,所有的API都要改,需要大调整,代码的耦合度非常高。如果在开发中程序员直接调用SLF4J提供的API,让SLF4J帮你做上面的工作,就能实现解耦合。

日志级别

日志级别从低到高

  1. trace:微量,少许的意思,级别最低
  2. debug: 调试时候的关键信息打印
  3. info: 普通的打印信息(默认日志级别)
  4. warm: 警告
  5. error: 错误信息,级别较高的错误日志信息
  6. fatal: 致命的,程序崩溃
    :::success
    日志级别设置
    :::
    日志级别设置需要在配置文件中设置“logging.level"
logging:
  level:
    root: error #设置根路径的日志级别
    com:
      example:
        demo:
          controller: warn #设置controller包的日志级别
@Controller
@ResponseBody //表示返回的是数据而非页面
@RequestMapping("/user")
public class UserController {
    //1. 得到日志对象
    private static final Logger logger = LoggerFactory.getLogger(UserController.class);//表示该日志来自于哪个类
    @RequestMapping("/hi")
    public String sayHi() {
        //写日志
        logger.trace("trace级别");
        logger.debug("debug级别");
        logger.info("info级别");
        logger.warn("warn级别");
        logger.error("error级别");
        return "hi";
    }
}

点击运行后,我们发现控制台空空如也,这是因为我们设置根路径的日志级别为error
image.png
发送请求,调用sayHi方法
image.png
日志打印如下
image.png
打印了warn和error日志,这是因为我们配置了controller包的最小日志级别是warn
:::info
日志级别的作用
:::

  1. 帮助我们快速筛选重要的日志
  2. 不同环境实现不同日志级别的设置

日志持久化

咱们上面的日志都是输出在控制台上,但是在生产环境上咱们需要将日志保存下来,以便出现问题之后追溯问题,这就需要持久化。

logging:
  file:
    path: D:\\javaee_advanced\\Test.2023.5.28

image.png
注意:后序的日志是采用续写的方式,而不是覆盖。并且当文件达到10M时会自动给你创建一个新的文件。

logging:
  file:
    name: springboot.log

如果没有指定路径,只给文件名会默认给你保存到项目中。
image.png

更简单的日志输出

在输出日志时,都需要获得日志对象并且每个类都需要添加一遍,非常麻烦。我们可以使用lombok框架的@slf4j注解 简化开发

@Controller
@ResponseBody //表示返回的是数据而非页面
@RequestMapping("/user")
@Slf4j  
public class UserController {
    //1. 得到日志对象
    //private static final Logger logger = LoggerFactory.getLogger(UserController.class);//表示该日志来自于哪个类
    @RequestMapping("/hi")
    public String sayHi() {
        //写日志
        log.trace("trace级别");
        log.debug("debug级别");
        log.info("info级别");
        log.warn("warn级别");
        log.error("error级别");
        return "hi";
    }
}

注意:使用Slf4j默认的日志对象是log

lombok原理

我们点开target文件(.class文件)就能发现其中的奥秘
image.png
发现@Slf4j注解在.class文件中消失了,多了一个日志对象log.
image.png

lombok就是在编译阶段将注解变成代码,简化了开发

文章来源:https://blog.csdn.net/weixin_61427900/article/details/134899545
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。