• SpringBoot日志相关进阶配置


    目录

    日志

    日记基础操作

     设置包的级别

     设置日志分组

    使用lombok中@Slf4j简化日志输出 

    日志输出格式控制

     文件记录日志

     设置日志文件

     日志文件详细配置


    日志

    日记基础操作

    编程期调试代码

    运营期记录信息

    记录日常运营重要信息(峰值流量,平均响应时长...)

    记录应用报错信息(错误堆栈)

    记录运维过程数据(扩容、报警..)

    创建的springboot工程中

    1. package com.comtroller;
    2. import org.slf4j.Logger;
    3. import org.slf4j.LoggerFactory;
    4. import org.springframework.web.bind.annotation.GetMapping;
    5. import org.springframework.web.bind.annotation.RequestMapping;
    6. import org.springframework.web.bind.annotation.RestController;
    7. @RestController
    8. @RequestMapping("/logs")
    9. public class LogController {
    10. //创建记录日志的对象
    11. private static final Logger log= LoggerFactory.getLogger(LogController.class);
    12. @GetMapping
    13. public String test(){
    14. log.info("info..");
    15. log.debug("debug..");
    16. log.warn("warn..");
    17. log.error("error..");
    18. return "Logging ...";
    19. }

    运行结果                   

     可以看出来debug级别的日志默认是关闭的

    要开启debug只需要在配置文件中加入

    1. //开启debug模式,输出调试信息,常用于检查系统运行状态
    2. debug: true

    一般这样设置

    1. 设置日志级别,root表示根节点,即整体应用日志级别
    2. logging:
    3. level:
    4. root: debug

     debug加载的信息量非常的多

    1. logging:
    2. level:
    3. root: warn

    改成warn级别,只要警告信息和报错信息

     设置包的级别

    1. logging:
    2. level:
    3. # 其余的日志为info级别
    4. root: info
    5. # 设置com包下的为debug
    6. com: debug

     设置日志分组

    设置日志组,控制指定包对应的日志输出级别,也可以直接控指定包对应的日志输出级别

    1. logging:
    2. group:
    3. # 自定义组名,设置当前组中所包含的包
    4. kc_g1: com
    5. # 设置日志级别
    6. level:
    7. root: warn
    8. kc_g1: debug

    可以使用继承的方式,将配置的抽取出来,放到一个类中,这就不用书写 

    将这个放到一个类中所用的类去继承

    1. //创建记录日志的对象
    2. private static final Logger log= LoggerFactory.getLogger(LogController.class);

    使用lombok中@Slf4j简化日志输出 

    pom.xml中引入lombok

    1. <dependency>
    2. <groupId>org.projectlombokgroupId>
    3. <artifactId>lombokartifactId>
    4. dependency>
    1. import lombok.extern.slf4j.Slf4j;
    2. import org.springframework.web.bind.annotation.GetMapping;
    3. import org.springframework.web.bind.annotation.RequestMapping;
    4. import org.springframework.web.bind.annotation.RestController;
    5. //lombok简化日志
    6. @Slf4j
    7. @RestController
    8. @RequestMapping("/logs")
    9. public class LogController {
    10. @GetMapping
    11. public String test(){
    12. log.info("info..");
    13. log.debug("debug..");
    14. log.warn("warn..");
    15. log.error("error..");
    16. return "Logging ...";
    17. }
    18. }

    运行之后

    日志输出格式控制

     PID:进程id,用于表明当前操作所处的进程,当多服务同时记录日志时,这个值可以用来协助调试程序

    所属类/接口:当前显示信息为SpringBoot重写后的信息,名称过长是,简化包名书写为首字母,甚至直接删除。

    设置日志输出格式

    1. logging:
    2. pattern:
    3. console: "%d %clr(%p) --- [%16t] %clr(%-40.40c){red} : %m %n"

    %d:日期

    %m:消息

    %n:换行

    %p: 进程号

    %clr:设置颜色

    %t:进程名

    -40:左对齐40位

    1. logging
    2. pattern:
    3. console: "%d - %m%n"

     文件记录日志

     设置日志文件

    1. logging:
    2. file:
    3. name: server.log

    一启动服务器就会生成一个你指定名字的文件,但是服务器没关是没有内容的,还在缓冲区里

     关闭服务器得到

     日志文件详细配置

    1. logging:
    2. file:
    3. name: server.log
    4. logback:
    5. rollingpolicy:
    6. max-file-size: 2KB
    7. file-name-pattern: server.%d{yyyy-MM-dd}.%i.log

     自动生成对应的

    注:SpringBoot2.4之后才能使用,否则无效果

  • 相关阅读:
    流程编排、如此简单-通用流程编排组件JDEasyFlow介绍
    SpringBoot自动配置原理
    SQL多个字段拼接组合成新字段的常用方法
    视频批量高效剪辑,轻松翻转视频画面,支持将视频画面进行逆时针90度翻转。
    eggjs的mvc模式demo(纯静态)
    16: KEil5的配置
    `Algorithm-Solution` `AcWing` 342. 道路与航线
    STM32存储左右互搏 QSPI总线FATS文件读写FLASH W25QXX
    数据排序(多字段数据排序)
    UTF-8字符串操作方法
  • 原文地址:https://blog.csdn.net/weixin_60719453/article/details/127260265