Spring Boot日志文件

这篇具有很好参考价值的文章主要介绍了Spring Boot日志文件。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

前言🍭

一、日志的作用🍭

1、日志真实使用案例:🍉

二、日志怎么用🍭

1、自定义日志打印🍉

Ⅰ、在程序中得到日志对象🍓

 常见的日志框架说明(了解)🍒

Ⅱ、使用日志对象打印日志 🍓

2、日志的级别🍉

Ⅰ、日志级别有什么用?🍓

Ⅱ、日志级别的分类与使用🍓

Ⅲ、日志级别设置🍓

Ⅳ、System.out.println() VS 日志🍓

3、日志持久化🍉

Ⅰ、配置日志文件的保存路径:🍓

路径:🍒

路径+文件名: 🍒

文件名: 🍒

Ⅱ、进行日志持久化 🍓

Ⅲ、日志是追加or覆盖?🍓

三、更简单的日志输出—lombok🍭

1、添加 lombok 依赖🍉

Ⅰ、旧项目添加新依赖框架 🍓

2、输出日志🍉

3、lombok原理解释🍉

4、lombok 更多注解说明🍉


前言🍭

❤️❤️❤️SSM专栏更新中,各位大佬觉得写得不错,支持一下,感谢了!❤️❤️❤️

Spring + Spring MVC + MyBatis_冷兮雪的博客-CSDN博客

前篇我们 讲完了SpringBoot的配置文件,讲解了为什么学配置文件&配置文件的作用,还有两种配置文件的格式与使用。这篇来讲SpringBoot 日志文件,下面我们一起进入SpringBoot 日志文件的世界!

一、日志的作用🍭

日志是程序的重要组成部分,想象一下,如果程序报错了,不让你打开控制台看日志,那么你能找到报错的原因吗?

答案是否定的,写程序不是买彩票,不能完全靠猜,因此日志对于我们来说,最主要的用途就是排除和定位问题。

Spring Boot日志文件用于记录应用程序的运行日志。它可以帮助开发人员在应用程序出现问题时进行故障排除和调试。以下是Spring Boot日志文件的几个用途:

  1. 故障排除:当应用程序发生错误或异常时,日志文件可以提供有关错误发生的上下文信息,如错误堆栈跟踪、错误消息等。开发人员可以根据这些信息来定位和修复问题。
  2. 调试:日志文件可以记录应用程序的运行过程中的详细信息,如请求参数、方法调用、返回结果等。这些信息可以帮助开发人员理解应用程序的运行流程,定位潜在的问题,并进行性能优化。
  3. 监控和性能分析:通过分析日志文件,开发人员可以获取应用程序的运行状态和性能指标,如请求响应时间、吞吐量、并发请求数等。这些信息可以帮助开发人员监控应用程序的健康状况,并进行性能分析和优化。
  4. 安全审计:日志文件可以记录应用程序的操作日志,如用户登录、数据修改等。这些信息可以用于安全审计和追踪用户行为。

所以 Spring Boot日志文件是开发人员在应用程序运行过程中进行故障排除、调试、性能分析和安全审计的重要工具。

1、日志真实使用案例:🍉

比如当我们去百度注册账号时,在注册时候百度不止要在后台添加 一条用户记录,同时也会给百度贴吧添加一条一模一样的用户记录,这样做的目的是为了实现一次注 册,多处使用的目的。不需要用户在两边系统注册了,等于在程序中以极低的成本实现的用户数据的同 步,但这样设计有一个致命的问题,用户在百度注册信息的时候,如果百度贴吧挂了,那么用户的注册 行为就会失败,因为用户在注册的时候需要同步注册到百度系统,但贴吧现在挂了,这个时候怎么办 呢?

最简单的解决方案,百度账号在注册的时候,不管贴吧是否注册成功,都给用户返回成功,如果注册失败了,记录一下日志,等贴吧恢复正常之后,把日志给贴吧的管理人员,让他手动将注册失败的用户同步到贴吧系统,这样就最低成本的解决了问题。这就是日志的重要作用。

二、日志怎么用🍭

Spring Boot 项目在启动的时候默认就有日志输出,如下图所示:

springboot 日志文件,Spring + Spring MVC + MyBatis,spring boot,java,spring

以上内容就是 Spring Boot 输出的控制台日志信息。 通过上述日志信息我们能发现以下 3 个问题:

  1. Spring Boot 内置了日志框架(不然也输出不了日志)。
  2. 默认情况下,输出的日志并是开发者定义和打印的,那开发者怎么在程序中自定义打印日志呢?
  3. 日志默认是打印在控制台上的,而控制台的日志是不能被保存的,那么怎么把日志永久的保存下来呢?

下面我们一起来找寻这些问题的答案。

1、自定义日志打印🍉

开发者自定义打印日志的实现步骤:
  • 在程序中得到日志对象。
  • 使用日志对象的相关语法输出要打印的内容

Ⅰ、在程序中得到日志对象🍓

在程序中获取日志对象需要使用日志工厂 LoggerFactory:

// 1.得到⽇志对象
private static Logger logger = LoggerFactory.getLogger(UserController.class);
//⽇志⼯⼚需要将每个类的类型传递进去,这样我们才知道⽇志的归属类,才能更⽅便、更直观的定位 到问题类。

Logger 对象是属于 org.slf4j 包下的,不要导入错包。

springboot 日志文件,Spring + Spring MVC + MyBatis,spring boot,java,spring

 常见的日志框架说明(了解)🍒

springboot 日志文件,Spring + Spring MVC + MyBatis,spring boot,java,spring

Ⅱ、使用日志对象打印日志 🍓

日志对象的打印方法有很多种,我们可以先使用 info() 方法来输出日志,如下代码所示

// 2.使⽤⽇志打印⽇志
@Controller//当前类为控制器
@ResponseBody//返回的是数据,而非页面
public class UserController {
    private static final Logger logger= LoggerFactory.getLogger(UserController.class);
    @RequestMapping("Hi")
    public String sayHi(){
        //写日志
        // 2.使⽤⽇志打印⽇志
        logger.info("--------------要输出⽇志的内容----------------");
        return "Hi,Spring Boot";
    }
}

打印信息 :

控制台打印:

springboot 日志文件,Spring + Spring MVC + MyBatis,spring boot,java,spring

浏览器打印(使用的是生产环境,生产环境设置的端口号为:7777):

springboot 日志文件,Spring + Spring MVC + MyBatis,spring boot,java,spring

2、日志的级别🍉

Ⅰ、日志级别有什么用?🍓

  • 日志级别可以控制不同环境下,⼀个程序是否需要打印日志,如开发环境我们需要很详细的信息, 而生产环境为了保证性能和安全性就会输入尽量少的日志,而通过日志的级别就可以实现此需求。
  • 日志级别可以帮你筛选出重要的信息,比如设置日志级别为 error,那么就可以只看程序的报错日志了,对于普通的调试日志和业务日志就可以忽略了,从而节省开发者信息筛选的时间。

Ⅱ、日志级别的分类与使用🍓

日志的级别分为:
  • trace:微量,少许的意思,级别最低;
  • debug:需要调试时候的关键信息打印;
  • info:普通的打印信息(默认日志级别);
  • warn:警告,不影响使用,但需要注意的问题;
  • error:错误信息,级别较高的错误日志信息;
  • fatal:致命的,因为代码异常导致程序退出执行的事件(软件或系统运行过程中发生了严重错误或异常,导致程序无法继续正常执行而必须终止的日志记录),我们是无法主动的去打印fatal日志。

    springboot 日志文件,Spring + Spring MVC + MyBatis,spring boot,java,spring

日志级别的顺序:

springboot 日志文件,Spring + Spring MVC + MyBatis,spring boot,java,spring

越往上接收到的消息就越少,如设置了 warn 就只能收到 warn、error、fatal 级别的日志了。

下面我们来看一下下面的代码,来更深入了解一下日志的级别:

@Controller//当前类为控制器
@ResponseBody//返回的是数据,而非页面
public class UserController {
    private static final Logger logger= LoggerFactory.getLogger(UserController.class);
    @RequestMapping("Hi")
    public String sayHi(){
        //写日志
        // 2.使⽤⽇志打印⽇志
        logger.trace("我是trace");
        logger.debug("我是debug");
        logger.info("我是info");
        logger.warn("我是warn");
        logger.error("我是error");
        return "Hi,Spring Boot";
    }
}

控制台打印:

springboot 日志文件,Spring + Spring MVC + MyBatis,spring boot,java,spring

我们发现只打印了三个,我们不是还打印了trace还有debug吗?

这是因为日志设置的默认级别是info,所以只能打印info级别下面的日志。

Ⅲ、日志级别设置🍓

日志级别配置只需要在配置文件中设置“logging.level”配置项即可:

#开发模式
#设置默认端口号
server:
  port: 7777
#设置默认日志等级
logging:
  level:
    root: trace

我们设置默认级别为:trace。看控制台打印:

springboot 日志文件,Spring + Spring MVC + MyBatis,spring boot,java,spring

我们看到设置为trace后,我们要求打印都打印了。但设置为trace之后,可能会导致日志文件过大或者打印输出过长,这可能会给查看和分析日志带来一些困难。

为了解决这个问题,可以考虑以下几个方法:

  1. 调整日志级别:将日志级别设置为更高的级别,例如将级别从trace调整为debug、info或者warn。这样可以减少不必要的日志输出,只保留关键信息。

  2. 筛选日志输出:通过使用日志过滤器或者正则表达式,只打印特定关键字或者模式匹配的日志信息。这样可以减少无关的日志输出,只保留需要的部分。

  3. 分割日志文件:设置日志文件大小限制或者定期将日志文件进行分割,可以防止单个日志文件过大。这样可以方便查看和管理日志文件。

  4. 使用日志分析工具:使用专门的日志分析工具,可以对大量的日志进行快速搜索、过滤和分析。这样可以更方便地查找和定位问题。

 所以在通常,默认 默认级别为info即可,看warn日志和error日志即可。对于warn和error级别的日志消息,你也可以选择查看。

日志级别的设置是特别灵活的,我们还可以针对不同的目录设置不同的日志级别

#开发模式
#设置默认端口号
server:
  port: 7777
#设置默认日志等级
logging:
  level:
    root: info
    com:
      example:
        springboard:info

有人说:我打印可以使用System.out.println()啊,为什么一定要使用日志呢?下面我们来比较一下 

Ⅳ、System.out.println() VS 日志🍓

  1. 灵活性:使用日志框架可以方便地控制日志的输出级别,从而在不同环境中灵活地开启或关闭日志输出。而使用System.out.println()则需要手动添加或删除代码。

  2. 可配置性:日志框架可以通过配置文件来设置日志的输出格式、输出位置等信息,而System.out.println()则只能将日志输出到控制台。

  3. 性能优化:日志框架会对日志进行缓冲和异步处理,以提高程序的性能。而System.out.println()会直接将日志输出到控制台,可能会对程序的性能造成一定的影响。

  4. 可扩展性:使用日志框架可以方便地扩展和替换日志实现,例如切换到其他日志框架或自定义日志输出方式。而使用System.out.println()则需要手动修改代码。

  5. System.out.println() 不能被持久化(可接着看后面便知晓了)。

3、日志持久化🍉

以上的日志都是输出在控制台上的,然而在生产环境上咱们需要将日志保存下来,以便出现问题之后追溯问题,把日志保存下来的过程就叫做持久化。

想要将日志进行持久化,只需要在配置文件中指定日志的存储目录或者是指定日志保存文件名之后, Spring Boot 就会将控制台的日志写到相应的目录或文件下了。

Ⅰ、配置日志文件的保存路径:🍓

路径:🍒
#开发模式
#设置默认端口号
server:
  port: 7777
#设置默认日志等级
logging:
  level:
    root: error
    com:
      example:
        springbootdemo: info
  # 设置⽇志⽂件的⽬录
  file:
    path: C:\\logs

在C盘创建应该logs文件夹:

springboot 日志文件,Spring + Spring MVC + MyBatis,spring boot,java,spring

路径+文件名: 🍒

 我们可以自己定义.log的文件名:

# 设置⽇志⽂件的⽂件名
logging:
 file:
 name: C:\\logs\\spring-1.log
文件名: 🍒
#开发模式
#设置默认端口号
server:
  port: 7777
#设置默认日志等级
logging:
  level:
    root: error
    com:
      example:
        springbootdemo: info
  # 设置⽇志⽂件的⽬录
  file:
      name: spring-1.log

如果直接指点文件名,那它就会直接在项目文件下直接生成.log文件:

springboot 日志文件,Spring + Spring MVC + MyBatis,spring boot,java,spring

Ⅱ、进行日志持久化 🍓

@Controller//当前类为控制器
@ResponseBody//返回的是数据,而非页面
public class UserController {
    private static final Logger logger= LoggerFactory.getLogger(UserController.class);
    @RequestMapping("Hi")
    public String sayHi(){
        //写日志
        // 2.使⽤⽇志打印⽇志
        logger.trace("我是trace");
        logger.debug("我是debug");
        logger.info("我是info");
        logger.warn("我是warn");
        logger.error("我是error");
        System.out.println("我是System。");
        return "Hi,Spring Boot";
    }
}

 运行代码:

打开控制台:

springboot 日志文件,Spring + Spring MVC + MyBatis,spring boot,java,spring

 打开logs:

springboot 日志文件,Spring + Spring MVC + MyBatis,spring boot,java,spring

 打开这spring.log:

springboot 日志文件,Spring + Spring MVC + MyBatis,spring boot,java,spring

 可以发现这和控制台打印的一模一样。但是没有打印 System.out.println(),这是因为日志的持久化只会保存日志信息,其他信息是不会去保存的。

Ⅲ、日志是追加or覆盖?🍓

如果我们重新运行代码,这个spring.log里面的内容是被覆盖还是被追加呢?

现在我们重新运行代码,打开spring.log看看:

springboot 日志文件,Spring + Spring MVC + MyBatis,spring boot,java,spring

可以看到日志的内容是追加的,所以不用担心日志会被覆盖或者消失,但是如果一直把它放在一个.log文件里面,那它越来越大,这怎么办啊?这时候就应该去查看一下官方文档:

官方文档

springboot 日志文件,Spring + Spring MVC + MyBatis,spring boot,java,spring

可以看到,日志持久化文件最大为10M,当超过10M是它会重新创建一个新的持久化文件。还有其他持久化设置,感兴趣的可以去了解一下。

三、更简单的日志输出—lombok🍭

每次都使用 LoggerFactory.getLogger(xxx.class) 很繁琐,且每个类都添加⼀遍,也很麻烦,这里讲⼀ 种更好用的日志输出方式,使用 lombok 来更简单的输出。

  1. 添加 lombok 框架支持。
  2. 使⽤ @slf4j 注解输出日志

1、添加 lombok 依赖🍉

<dependency>
<groupId>org.projectlombok</groupId>
 <artifactId>lombok</artifactId>
 <version>1.18.20</version>
 <optional>true</optional>
</dependency>

但是我们在创建Spring Boot时就已经导入了Lombok框架了: 

springboot 日志文件,Spring + Spring MVC + MyBatis,spring boot,java,spring

pom.xml:

springboot 日志文件,Spring + Spring MVC + MyBatis,spring boot,java,spring

Ⅰ、旧项目添加新依赖框架 🍓

安装EditStarters

springboot 日志文件,Spring + Spring MVC + MyBatis,spring boot,java,spring

然后在pom.xml里面右键选择 Generate

springboot 日志文件,Spring + Spring MVC + MyBatis,spring boot,java,spring

选择Edit Starters 

springboot 日志文件,Spring + Spring MVC + MyBatis,spring boot,java,spring

 点击OK

springboot 日志文件,Spring + Spring MVC + MyBatis,spring boot,java,spring

添加需要添加的依赖:

springboot 日志文件,Spring + Spring MVC + MyBatis,spring boot,java,spring

添加完成之后,重新reload就行了。

2、输出日志🍉

package com.example.springbootdemo;

import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

@Controller//当前类为控制器
@ResponseBody//返回的是数据,而非页面
@Slf4j
public class ArticleController {
    @RequestMapping("art")
    public String sayHi(){
        //写日志
        // 2.使⽤⽇志打印⽇志
        log.trace("我是trace");
        log.debug("我是debug");
        log.info("我是info");
        log.warn("我是warn");
        log.error("我是error");
        return "Hi,Article";
    }
}

注意:使用 @Slf4j 注解,在程序中使用 log 对象即可输入日志,并且只能用 log 对象才能输出这是 lombok 提供的对象名 

控制台打印: 

springboot 日志文件,Spring + Spring MVC + MyBatis,spring boot,java,spring

3、lombok原理解释🍉

lombok 能够打印日志的密码就在 target 目录里面,target 为项目最终执行的代码,查看 target 目录。如下:

自己所写的代码:

springboot 日志文件,Spring + Spring MVC + MyBatis,spring boot,java,spring

在target目录中,您可以找到编译后的项目代码

springboot 日志文件,Spring + Spring MVC + MyBatis,spring boot,java,spring

可以看到lombok会直接给你生成注释对应的代码 ,这就特别省事了。

Java 程序的运行原理

springboot 日志文件,Spring + Spring MVC + MyBatis,spring boot,java,spring

 Lombok 的作⽤如下图所示:

springboot 日志文件,Spring + Spring MVC + MyBatis,spring boot,java,spring

4、lombok 更多注解说明🍉

基本注解

注解

作用

@Getter

自动添加getter方法

@Setter

自动添加setter方法

@ToString

自动添加toString 方法

@EqualsAndHashCode

自动添加equals 和hashCode 方法

@NoArgsConstructor

自动添加无参构造方法

@AllArgsConstructor

自动添加全属性构造方法,顺序按照属性的定义顺序

@NonNull

属性不能为null

@RequiredArgsConstructor

自动添加必需属性的构造方法,final +@NonNull的属性为必需

组合注解

注解 作用
@Data @Getter + @Setter +@ToString +
@EqualsAndHashCode +
@RequiredArgsConstructor +
@NoArgsConstructor

⽇志注解  

注解
作⽤
@Slf4j
添加一个名为 log 的日志,使用slf4j

springboot 日志文件,Spring + Spring MVC + MyBatis,spring boot,java,spring文章来源地址https://www.toymoban.com/news/detail-800881.html

到了这里,关于Spring Boot日志文件的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【JavaEE】Spring Boot - 日志文件

    【JavaEE】Spring Boot 开发要点总结(3) 写代码不是概率事件,bug的出现必然是有原因的,而日志的主要作用就是,排查和定位问题! 而日志的生成就是随着程序的进行和一步步生成的,不说全部过程都记录得清清楚楚,至少重要的点和环节或者一些异常情况都有记录 而通过日

    2024年02月14日
    浏览(39)
  • Spring Boot 配置文件和日志

    目录 配置文件格式 properties配置文件说明 1.properties基本语法 2.读取配置文件 3.properties缺点 yml配置文件说明 1.yml基本语法 2.配置不同数据类型 3.字符串特殊情况 4.配置对象 properties和yml对比 日志 日志的使用 日志级别 日志持久化 Lombok Lombok原理解释 Spring中配置文件有很重要的

    2024年01月19日
    浏览(42)
  • Spring Boot配置保存日志文件

    springboot日志配置: springboot默认日志是打印再console中的,不会保存在文件中。我们项目上线肯定要保存日志用于分析的。 一、使用xml配置日志保存(并不需要pom配置slf4j依赖,starter里面已经配置了依赖了) 1、在项目的resources目录下创建一个【logback-spring.xml】日志配置文件

    2024年02月11日
    浏览(32)
  • 【Spring Boot学习二】日志文件

    目录 🌷1、自定义输出日志 🌷 2、日志级别 2.1 日志级别分类(6种) 2.2 配置日志级别(在.yml文件中设置:) (1)设置日志整体级别 (2)分目录设置日志级别 🌷3、日志怎么持久化 3.1 设置日志文件名和路径(.yml文件下配置)  3.2 对日志分割:每隔多少M分割 🌷4、更简单的

    2024年02月16日
    浏览(39)
  • 【Java】Spring Boot 日志文件

    日志是程序的重要组成部分,想象一下,如果程序报错了,不让你打开控制台看日志,那么你能找到报错的原因吗。 日志对于我们来说,最主要的用途就是排除和定位问题。除了发现和定位问题之外,我们还可以通过日志实现以下功能: 记录用户登录日志,方便分析用户是

    2024年02月01日
    浏览(40)
  • Spring Boot配置文件及日志信息

    目录 前言: Spring Boot优点 配置文件 配置文件格式 读取配置文件 properties配置文件格式 properties优缺点分析 yml配置文件格式(另一种标记语言) yml优缺点分析 Spring Boot 不同平台配置文件规则 日志信息 日志的功能 Spring Boot内置日志框架 使用日志 得到日志对象 打印日志 日志

    2024年02月01日
    浏览(50)
  • 【SpringBoot】Spring Boot 项目中整合 MyBatis 和 PageHelper

    目录 前言         步骤 1: 添加依赖 步骤 2: 配置数据源和 MyBatis 步骤 3: 配置 PageHelper 步骤 4: 使用 PageHelper 进行分页查询 IDEA指定端口启动 总结         Spring Boot 与 MyBatis 的整合是 Java 开发中常见的需求,特别是在使用分页插件如 PageHelper 时。PageHelper 是一个针对 MyBat

    2024年04月25日
    浏览(28)
  • 【Spring Boot学习】日志文件,Spring Boot也会写日记了,这些事你知道嘛 ? ? ?

    前言: 大家好,我是 良辰丫 ,在上一篇文章中我们已经学习了Spring Boot的配置,接下来我们要学习一些日志相关的东西,什么是日志呢?我们慢慢往下看.💌💌💌 🧑个人主页:良辰针不戳 📖所属专栏:javaEE进阶篇之框架学习 🍎励志语句:生活也许会让我们遍体鳞伤,但最终这些

    2024年02月08日
    浏览(35)
  • Java EE 突击 9 - Spring Boot 日志文件

    这个专栏给大家介绍一下 Java 家族的核心产品 - SSM 框架 JavaEE 进阶专栏 Java 语言能走到现在 , 仍然屹立不衰的原因 , 有一部分就是因为 SSM 框架的存在 接下来 , 博主会带大家了解一下 Spring、Spring Boot、Spring MVC、MyBatis 相关知识点 并且带领大家进行环境的配置 , 让大家真正用好

    2024年02月13日
    浏览(35)
  • Spring Boot入门(10):Mybatis之XML映射文件>、<=等特殊符号使用 | 保姆级教程

            在Mybatis的XML映射文件中,我们经常需要使用一些特殊符号来完成SQL语句的拼接,比如小于号“”、小于等于号“=”等。然而,由于这些符号在XML中有特殊的含义,因此直接在映射文件中使用可能会导致编译错误或者运行时异常。那么,如何才能正确地使用这些特殊

    2024年02月11日
    浏览(41)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包