SpringBoot —— 日志基本操作

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: SpringBoot —— 日志基本操作



@(SpringBoot —— 日志基本操作)

一、日志的作用


日志(log)作用:

1.编程期调试代码

2.运营期记录信息

  • 记录日常运营重要信息(峰值流量、平均响应时长…)
  • 记录应用报错信息(错误堆栈)
  • 记录运维过程数据(扩容、宕机、报警…)



二、日志级别


  • TRACE: 运行堆栈信息,使用率低
  • DEBUG: 程序员调试代码使用
  • INFO: 记录运维过程数据
  • WARN: 记录运维过程报警数据
  • ERROR: 记录错误堆栈信息
  • FATAL: 灾难信息,合并计入ERROR



三、日志的使用


  1. 控制层组件中,创建记录日志的对象,并记录日志信息
  • 日志默认使用info级别,只能看到info及以上级别的信息,此时debug级别的日志信息不可见
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;
/**
 * @author .29.
 * @create 2023-03-31 19:40
 */
@RestController
@RequestMapping("/books")
public class BookController {
    //一、创建记录日志的对象
    private static final Logger log = LoggerFactory.getLogger(BookController.class);
    @GetMapping
    public String get(){
        System.out.println("SpringBoot is running ...");
        //二、记录日志信息
        //日志默认使用info级别,只能看到info及以上级别的信息,此时debug级别的日志信息不可见
        log.debug("debug...");
        log.info("info...");
        log.warn("warn...");
        log.error("error...");
        return "test springboot use log";
    }
}


  • 快速创建日志对象的技巧:

导入lombok依赖,在控制层组件使用 @Slf4j 注解

<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;
/**
 * @author .29.
 * @create 2023-03-31 19:40
 */
@Slf4j
@RestController
@RequestMapping("/books")
public class BookController {
    //一、创建记录日志的对象
//    private static final Logger log = LoggerFactory.getLogger(BookController.class);
    @GetMapping
    public String get(){
        System.out.println("SpringBoot is running ...");
        //二、记录日志信息
        //日志默认使用info级别,只能看到info及以上级别的信息,此时debug级别的日志信息不可见
        log.debug("debug...");
        log.info("info...");
        log.warn("warn...");
        log.error("error...");
        return "test springboot use log";
    }
}



  1. 显示debug级别日志信息的方案

在SpringBoot配置文件application.yml中设置

方式一:

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


方式二(推荐):

# 方式一:开启debug模式,输出调试信息,常用于检查系统运行状况
#debug: true   
# 方式二:设置日志级别,root表示根节点,即整体应用日志级别
logging:
  level:
    root: debug




四、设置日志级别


在SpringBoot配置文件application.yml中设置


  • 单独设置某个包的日志级别
# 整体应用info级别,单独设置某个包为debug级别
logging:
  level:
    root: info
    com.haojin.springboot.springbootlog.controller: debug  # 单独设置某个包的日志级别


  • 设置分组,对某个组设置日志级别
# 设置日志级别
logging:
  level:
    root: info
    # 对组ebank设置日志级别为debug
    ebank: debug
  # 设置分组ebank
  group:
    ebank: com.haojin.springboot.springbootlog.controller,com.haojin.springboot.springbootlog.service



五、设置日期输出格式


在SpringBoot配置文件application.yml中设置

  • %d —— 日期
  • %m —— 消息
  • %n —— 换行
# 设置日志输出格式
loggin:
  pattern:
    console: "%d - %m%n"



六、日志写入文件


  • 设置日志文件:server.log 中
# 日志会写入日志文件:
logging:
  file:
    name: server.log


  • 日志文件详细配置:
logging:
    name: server.log
  logback:
    rollingpolicy:
      max-file-size: 10KB  #设置文件极限大小
      file-name-pattern: server.%d{yyyy-MM-dd}.%i.log #设置日志命名格式




相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
目录
相关文章
|
6天前
|
SQL 监控 Java
在IDEA 、springboot中使用切面aop实现日志信息的记录到数据库
这篇文章介绍了如何在IDEA和Spring Boot中使用AOP技术实现日志信息的记录到数据库的详细步骤和代码示例。
在IDEA 、springboot中使用切面aop实现日志信息的记录到数据库
|
12天前
|
消息中间件 存储 Java
手动实现 Spring Boot 日志链路追踪:提升调试效率的利器
【8月更文挑战第8天】在复杂的分布式系统中,日志是诊断问题、追踪系统行为的重要工具。然而,随着微服务架构的普及,服务间的调用链路错综复杂,传统的日志记录方式往往难以快速定位问题源头。今天,我们将探讨如何在不依赖外部组件(如Zipkin、Sleuth等)的情况下,手动实现Spring Boot应用的日志链路追踪,让日志定位更加便捷高效。
33 1
|
7天前
|
存储 监控 Java
|
5天前
|
XML Java Maven
logback在springBoot项目中的使用 springboot中使用日志进行持久化保存日志信息
这篇文章详细介绍了如何在Spring Boot项目中使用logback进行日志记录,包括Maven依赖配置、logback配置文件的编写,以及实现的日志持久化和控制台输出效果。
logback在springBoot项目中的使用 springboot中使用日志进行持久化保存日志信息
|
9天前
|
XML Java 数据库
"揭秘!Spring Boot日志链路追踪大法,让你的调试之路畅通无阻,效率飙升,问题无所遁形!"
【8月更文挑战第11天】在微服务架构中,请求可能跨越多个服务与组件,传统日志记录难以全局追踪问题。本文以电商系统为例,介绍如何手动实现Spring Boot应用的日志链路追踪。通过为每个请求生成唯一追踪ID并贯穿全链路,在服务间传递该ID,并在日志中记录,即使日志分散也能通过ID串联。提供了实现这一机制所需的关键代码片段,包括使用过滤器设置追踪ID、业务代码中的日志记录及Logback配置。此方案显著提升了问题定位的效率,适用于基于Spring Boot构建的微服务环境。
22 4
|
8天前
|
Java 数据库连接 Spring
SpringBoot——日志【六】
SpringBoot——日志【六】
10 0
SpringBoot——日志【六】
|
8天前
|
Java 应用服务中间件
SpringBoot 记录 access.log 日志
SpringBoot 记录 access.log 日志
19 0
SpringBoot 记录 access.log 日志
|
6天前
|
Java Windows Spring
Spring Boot CMD 运行日志输出中文乱码
Spring Boot CMD 运行日志输出中文乱码
7 0
|
8天前
|
Java
SpringBoot 拦截器 统一日志 记录用户请求返回日志
SpringBoot 拦截器 统一日志 记录用户请求返回日志
10 0
|
8天前
|
Java Spring
Spring Boot Admin 查看 Client 日志
Spring Boot Admin 查看 Client 日志
11 0

热门文章

最新文章