SpringBoot日志配置操作全面介绍

 更新时间:2022年10月24日 10:02:52   作者:执久呀  
日志,通常不会在需求阶段作为一个功能单独提出来,也不会在产品方案中看到它的细节。但是,这丝毫不影响它在任何一个系统中的重要的地位,这篇文章主要介绍了SpringBoot日志配置

日记基础操作

编程期调试代码

运营期记录信息

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

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

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

创建的springboot工程中

package com.comtroller;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
@RequestMapping("/logs")
public class LogController {
    //创建记录日志的对象
    private static  final Logger log= LoggerFactory.getLogger(LogController.class);
    @GetMapping
    public String test(){
       log.info("info..");
       log.debug("debug..");
       log.warn("warn..");
       log.error("error..");
        return "Logging ...";
    }

运行结果

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

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

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

一般这样设置

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

debug加载的信息量非常的多

logging:
  level:
    root: warn

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

设置包的级别

logging:
  level:
#    其余的日志为info级别
    root: info
#    设置com包下的为debug
    com: debug

设置日志分组

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

logging:
  group:
#    自定义组名,设置当前组中所包含的包
    kc_g1: com
#    设置日志级别
  level:
    root: warn
    kc_g1: debug

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

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

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

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

pom.xml中引入lombok

<!--        lombok简化日志输出-->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>
import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
//lombok简化日志
@Slf4j
@RestController
@RequestMapping("/logs")
public class LogController {
    @GetMapping
    public String test(){
       log.info("info..");
       log.debug("debug..");
       log.warn("warn..");
       log.error("error..");
        return "Logging ...";
    }
}

运行之后

日志输出格式控制

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

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

设置日志输出格式

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

%d:日期

%m:消息

%n:换行

%p: 进程号

%clr:设置颜色

%t:进程名

-40:左对齐40位

logging
  pattern:
    console: "%d - %m%n" 

文件记录日志

设置日志文件

logging:
  file:
    name: server.log

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

关闭服务器得到

日志文件详细配置

logging:
  file:
    name: server.log
  logback:
    rollingpolicy:
      max-file-size: 2KB
      file-name-pattern: server.%d{yyyy-MM-dd}.%i.log

自动生成对应的

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

到此这篇关于SpringBoot日志配置操作全面介绍的文章就介绍到这了,更多相关SpringBoot日志配置内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Java利用jenkins做项目的自动化部署

    Java利用jenkins做项目的自动化部署

    这篇文章主要介绍了Java利用jenkins做项目的自动化部署,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-06-06
  • SpringBoot @RestControllerAdvice注解对返回值统一封装的处理方法

    SpringBoot @RestControllerAdvice注解对返回值统一封装的处理方法

    这篇文章主要介绍了SpringBoot @RestControllerAdvice注解对返回值统一封装,使用@RestControllerAdvice对响应进行增强,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-09-09
  • Spring Task任务调度的实现示例

    Spring Task任务调度的实现示例

    本文主要介绍了Spring Task任务调度的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-06-06
  • idea安装jerbel及文件上传下载的实现示例

    idea安装jerbel及文件上传下载的实现示例

    JRebel是一个Java开发工具,它是一款用于实时代码重载的插件,本文主要介绍了idea安装jerbel及文件上传下载的实现示例,具有一定的参考价值,感兴趣的可以了解下
    2023-09-09
  • idea http request无法识别环境变量的解决步骤

    idea http request无法识别环境变量的解决步骤

    AlibabaCloudToolkit插件安装后在 Editor->File Types增加 AlibabaCloudROStemplates(JSON)项且会配置为解析*.json 文件,导致http client无法正确解析http-client.env.json文件而无法读取环境变量,本文介绍idea http request无法识别环境变量问题,需要的朋友可以参考下
    2023-08-08
  • Java基础教程之字符流文件读写

    Java基础教程之字符流文件读写

    这篇文章主要给大家介绍了关于Java基础教程之字符流文件读写的相关资料,,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-07-07
  • Java安全后端返回文件流方式

    Java安全后端返回文件流方式

    这篇文章主要介绍了Java安全后端返回文件流方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-07-07
  • spring boot发简单文本邮件案例

    spring boot发简单文本邮件案例

    这篇文章主要介绍了spring boot发简单文本邮件案例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-10-10
  • Java使用opencv识别二维码的完整步骤

    Java使用opencv识别二维码的完整步骤

    OpenMV是一个开源,低成本,功能强大的机器视觉模块,下面这篇文章主要给大家介绍了关于Java使用opencv识别二维码的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2021-09-09
  • 使用maven创建普通项目命令行程序详解

    使用maven创建普通项目命令行程序详解

    大部分使用maven创建的是web项目,这里使用maven创建一个命令行程序,目的是让大家了解maven特点和使用方式,有需要的朋友可以借鉴参考下
    2021-10-10

最新评论