认识springboot 之 了解它的日志 -4

chatgpt/2023/9/24 1:16:57

前言

本篇介绍springboot的日志,如何认识日志,如何进行日志持久化,通过日志级别判断信息,了解Lombok插件的使用,通过Lombok自带注释更简洁的来完成日志打印,如有错误,请在评论区指正,让我们一起交流,共同进步!


文章目录

  • 前言
  • 1.日志的作用
  • 2. 识别日志信息
  • 3. 认识日志级别
  • 4. 日志持久化
  • 5. 认识 Lombok
  • 总结

本文开始

1.日志的作用

日志的作用:记录信息,方便以后查看;打印错误信息,方便自己找出错误;

2. 识别日志信息

先来认识springboot默认打印的日志:
日志的默认格式:

在这里插入图片描述日志级别:用来筛选日志信息

  • 日志级别:(info是默认日志级别)打印日志小于info日志级别的日志不会打印;

3. 认识日志级别

日志级别的作用:过滤信息,去掉业务不需要的日志;
日志级别:

trace: 微量,少许,日志级别最低;
debug: 调试日志级别;
info: 普通日志级别;
warn: 警告日志级别;
error: 错误日志级别
fatal: 致命日志级别,只要系统在崩溃时才会输入的日志级别,级别最高;

根据日志的作用,可能有时需要修改默认的日志级别:
修改方式:在配置文件中修改即可,logging.level+root/包名;

#修改项目日志默认级别
logging.level.root=warn
#修改项目中某一个目录的日志级别: logging.level+包名
logging.level.com.example.demo.controller=debug

思考:springboot为什么可以打印日志,并设置日志?

springboot中内置俩个日志框架:slf4j + LogBack;
slf4j框架作用:让开发者 使用 和 调用 的框架;- 操作不用考虑底层
LogBack框架作用:它最底层是实现日志相关操作的框架;- 例如:打印日志等底层操作;

4. 日志持久化

日志持久化:为防止日志的丢失,需要将日志存储到硬盘中,来实现日志持久化;

下面介绍两种持久化日志的方式:

  • 设置日志保存的路径:在对应的配置文件中设置
    生成的日志文件内容,会追加到旧日志下面;
logging.file.path=D:\\dp\\
  • 设置日志的保存文件名:下面是路径+文件名
logging.file.name=D:\\dp\\spr_boot.log

5. 认识 Lombok

Lombok : 一个java库,用来增强java性能;例如:通过注释来代替去写setter,getter等方法;

Lombok中好用的两个注解:@Data 与 @Slf4j

  • @Date组合注解:使用该注解,就包含了以下注解的功能;
    @Getter : ⾃动添加 getter ⽅法
    @Setter : ⾃动添加 setter ⽅法
    @ToString : ⾃动添加 toString ⽅法
    @EqualsAndHashCode : ⾃动添加 equals + hashCode ⽅法
    @RequiredArgsConstructor : 自动添加必要属性的构造方法 (final 与 @NonNull 属性为必须属性)
    @NoArgsConstructor :自动添加无参构造方法
    【注】@NonNull : 属性不能为 null

  • @Slf4j注释:该注释产生一个 日志对象,就获取日志对象log

// @Slf4j == private static Logger log = LoggerFactory.getLogger(Test.clss); 
// 不写注释就需要根据这行代码获取日志对象

Lombok为什么能实现呢?
Lombok 的 实现原理:

在编译阶段,Lombok 与 用户代码.java文件 一起生成字节码.class文件,
这个过程中Lombok将对应的注释功能,转换为了注释对应方法的代码;再一起在JVM上运行;

  • Lombok + .java =》.class =》JVM

总结

✨✨✨各位读友,本篇分享到内容如果对你有帮助给个👍赞鼓励一下吧!!
感谢每一位一起走到这的伙伴,我们可以一起交流进步!!!一起加油吧!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.exyb.cn/news/show-5312980.html

如若内容造成侵权/违法违规/事实不符,请联系郑州代理记账网进行投诉反馈,一经查实,立即删除!

相关文章

笙默考试管理系统-MyExamTest(22)

笙默考试管理系统-MyExamTest(22) 目录 一、 笙默考试管理系统-MyExamTest 二、 笙默考试管理系统-MyExamTest 三、 笙默考试管理系统-MyExamTest 四、 笙默考试管理系统-MyExamTest 五、 笙默考试管理系统-MyExamTest 笙默考试管理系统-MyExa…

c++(强生成关键字+可变参数模板+emplace)[26]

强制生成 不生成 在C中,可以通过一些方式来控制编译器是否生成某些特殊成员函数(如默认构造函数、拷贝构造函数、拷贝赋值运算符、析构函数等)。 默认生成:如果你没有显式地定义这些特殊成员函数,编译器会自动生成它们…

【性能优化篇】.ttf字体包过大引起的网页加载过慢 font-spider 压缩字体包 适用于任何前端项目

背景 项目使用的是阿里巴巴普惠2.0字体,型号分别是 35-thin 和 45-light 这两个字体包 都是 8mb 左右 本地加载的时候可能速度不会收影响,发到生产和测试环境下,速度会很慢,尤其是测试环境,字体包加载了一分钟&#…

Qt+OpenCV+VTK在VS2017中配置路径

QtOpenCVVTK在VS2017中配置路径 《Qt环境配置》《OpenCV环境配置》《VTK环境配置》 《Qt环境配置》 包含目录: D:\Qt\Qt5.12.11\5.12.11\msvc2017_64\include D:\Qt\Qt5.12.11\5.12.11\msvc2017_64\include\QtWidgets D:\Qt\Qt5.12.11\5.12.11\msvc2017_64\include…

Java maven的下载解压配置(保姆级教学)

mamen基本概念 Maven项目对象模型(POM),可以通过一小段描述信息来管理项目的构建,报告和文档的项目管理工具软件。 Maven 除了以程序构建能力为特色之外,还提供高级项目管理工具。由于 Maven 的缺省构建规则有较高的可重用性,所以…

并发编程——线程池

1.概述 如果并发的线程过多,而且执行的时间都非常短,如果这样,每次都要创建线程就会大大降低效率,我们可以通过线程池来解决,JDK5增加了内置线程池ThreadPollExecutor。 2.线程池的优点 1.重复利用,降低…

第三课:运算符

1.算数运算符 int a 20; int b 10; System.out.println(a b); // 30 System.out.println(a - b); // 10 System.out.println(a * b); // 200 System.out.println(a / b); // 2 System.out.println(a % b); // 0 --->模运算相当于数学中除法的余数 ⚠关于/除法 public s…
推荐文章