SpringBoot日志

自定义日志

导入的是slf4j的Logger类

java 复制代码
package app.controller;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.bind.annotation.GetMapping;

@RestController
public class TestController {
    // 得到日志对象
    private static Logger logger = LoggerFactory.getLogger(TestController.class);

    @GetMapping("/log")
    public void getLog() {
        logger.info("Customer log");
    }
}

运行效果

设置日志级别

日志级别(低->高):trace->debug->info->warn->error

Spring中默认级别: info

root: warn解释:如果SpringBoot中没有为特定的包设置日志级别那么就会使用warn作为默认的日志级别

当设置为warn之后,控制台只会输出大于等于warn级别的日志信息

日志持久化

日志不会覆盖而是追加的方式添加,日志文件太大的时候会自动分割

yaml 复制代码
# 设置路径
logging:
  file:
    path: D:\100.Documents\200.IntelliJIDEA\projects\spring_study\springboot-demo1\src\main\resources\static
yaml 复制代码
# 设置名称
logging:
  file:
    name: springboot.log

结合lombok使用@Slf4j快速添加日志

这些日志会发现每次在使用的时候需要填写对应的类信息才行

java 复制代码
private static Logger logger = LoggerFactory.getLogger(LogController.class);

lombok可以省略掉这一步,哪一个类运行就获取哪一个类的字节码

对比 getLog2 可以更简洁的输出日志

java 复制代码
package app.controller;

import lombok.extern.slf4j.Slf4j;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
@Slf4j
public class LogController {
    //1.得到日志对象
    private static Logger logger = LoggerFactory.getLogger(LogController.class);

    @GetMapping("/log1")
    public void getLog1() {
        logger.trace("trace");
        logger.debug("debug");
        logger.info("info");
        logger.warn("warn");
        logger.error("error");
    }

    @GetMapping("/log2")
    public void getLog2() {
        log.trace("trace");
        log.debug("debug");
        log.info("info");
        log.warn("warn");
        log.error("error");
    }
}

查看字节码文件会发现@Slf4j的运行原理

说明程序是在编译期自动添加的这一行代码,包括lombok的@Data注解也会自动生成getter、setter、equals、canEqual、hashCode、toString方法都是在编译期生成的代码

相关推荐
汤姆yu3 小时前
基于springboot的尿毒症健康管理系统
java·spring boot·后端
暮色妖娆丶3 小时前
Spring 源码分析 单例 Bean 的创建过程
spring boot·后端·spring
biyezuopinvip4 小时前
基于Spring Boot的企业网盘的设计与实现(任务书)
java·spring boot·后端·vue·ssm·任务书·企业网盘的设计与实现
JavaGuide4 小时前
一款悄然崛起的国产规则引擎,让业务编排效率提升 10 倍!
java·spring boot
figo10tf5 小时前
Spring Boot项目集成Redisson 原始依赖与 Spring Boot Starter 的流程
java·spring boot·后端
zhangyi_viva5 小时前
Spring Boot(七):Swagger 接口文档
java·spring boot·后端
橙露5 小时前
Spring Boot 核心原理:自动配置机制与自定义 Starter 开发
java·数据库·spring boot
程序员敲代码吗5 小时前
Spring Boot与Tomcat整合的内部机制与优化
spring boot·后端·tomcat
NuageL5 小时前
原始Json字符串转化为Java对象列表/把中文键名变成英文键名
java·spring boot·json
jzheng86106 小时前
Spring Boot(快速上手)
java·spring boot·后端