SpringBoot 日志

一、概述

日志是程序的重要组成部分,程序报错了,我们可以通过查看日志信息排除和定位问题。

二、日志格式

在启动 SpringBoot 项目时,控制台中默认会打印一些日志,下面我们截取一段日志信息,分析一下日志的格式:

为什么 SpringBoot 可以设置并打印日志?

因为其内部内置了两个日志框架: SLF4J(让开发者使用和调用的框架) 和 logback(最底层实现日志相关操作的框架)

三、日志级别

日志的级别分为:

  • trace:微量,少许的意思,级别最低;
  • debug:需要调试时候的关键信息打印;
  • info:普通的打印信息(默认日志级别);
  • warn:警告,不影响使用,但需要注意的问题;
  • error:错误信息,级别较高的错误日志信息;
  • fatal:致命的,因为代码异常导致程序退出执行的事件。(只有系统能输出)

1、日志级别的作用?

日志级别可以帮我们筛选出重要的信息,将业务不需要的日志屏蔽掉。例如日志级别设置为 error 时,那么就可以只看程序的报错日志了,对于普通的调试日志和业务日志就可以忽略了。

2、如何设置日志级别?

只需要在配置文件进行简单配置即可。

例如设置根路径的日志级别为 error:

java 复制代码
# 在 properties 文件中设置日志级别为 error
logging.level.root=error

给 com.example.demo.model 目录下的类设置日志级别:

java 复制代码
# 在 properties 文件中设置日志级别为 error
logging.level.com.example.demo.model=error

四、自定义日志打印

自定义日志打印主要分为两步:

  1. 在程序中得到日志对象。
  2. 使用日志对象提供的打印方法输出要打印的内容。

方式一: Logger 对象是属于 org.slf4j 包下的,我们使用日志工厂 LoggerFactory 来获取到日志对象:

java 复制代码
private static Logger logger = LoggerFactory.getLogger(类对象);

注: 这里 LoggerFactory.getLogger() 方法中的参数是用来指定日志记录器(Logger)的名称的。通常情况下,建议使用当前类的 Class 对象作为参数,以便在日志输出时能够正确标识出日志信息所属的类。

java 复制代码
@Controller
@ResponseBody
public class LogController {
    private static Logger logger =
            LoggerFactory.getLogger(LogController.class);
    @RequestMapping("/log")
    public void log() {
        logger.trace("trace 级别的日志信息");
        logger.debug("debug 级别的日志信息");
        logger.info("info 级别的日志信息");
        logger.warn("warn 级别的日志信息");
        logger.error("error 级别的日志信息");
    }
}

方式二: 使用 lombok

java 复制代码
@Controller
@ResponseBody
@Slf4j
public class LogController {
    @RequestMapping("/log")
    public void log() {
        log.trace("trace 级别的日志信息");
        log.debug("debug 级别的日志信息");
        log.info("info 级别的日志信息");
        log.warn("warn 级别的日志信息");
        log.error("error 级别的日志信息");
    }
}

注: 使用 @Slf4j 注解会在当前类下添加一个名为 log 的日志对象。

注: 因为默认日志级别为 info ,因此仅输出级别大于等于 info 级别的日志。

五、日志持久化

以上的日志都是输出在控制台上的,然而在生产环境上咱们需要将日志保存下来,以便出现问题后进行追随。要将日志进行持久化,只需要在配置文件中指定日志的存储目录Spring Boot 就会将控制台的日志写到相应的目录下。

例如设置日志的存储的相对目录为 log:

java 复制代码
# 设置日志的存储的相对目录为 ./log
logging.file.path=./log
相关推荐
小二·几秒前
java基础面试题笔记(基础篇)
java·笔记·python
开心工作室_kaic23 分钟前
ssm161基于web的资源共享平台的共享与开发+jsp(论文+源码)_kaic
java·开发语言·前端
懒洋洋大魔王25 分钟前
RocketMQ的使⽤
java·rocketmq·java-rocketmq
武子康30 分钟前
Java-06 深入浅出 MyBatis - 一对一模型 SqlMapConfig 与 Mapper 详细讲解测试
java·开发语言·数据仓库·sql·mybatis·springboot·springcloud
qq_17448285751 小时前
springboot基于微信小程序的旧衣回收系统的设计与实现
spring boot·后端·微信小程序
转世成为计算机大神1 小时前
易考八股文之Java中的设计模式?
java·开发语言·设计模式
qq_327342731 小时前
Java实现离线身份证号码OCR识别
java·开发语言
阿龟在奔跑3 小时前
引用类型的局部变量线程安全问题分析——以多线程对方法局部变量List类型对象实例的add、remove操作为例
java·jvm·安全·list
飞滕人生TYF3 小时前
m个数 生成n个数的所有组合 详解
java·递归
代码小鑫3 小时前
A043-基于Spring Boot的秒杀系统设计与实现
java·开发语言·数据库·spring boot·后端·spring·毕业设计