• Spring Boot 日志文件


    🎉🎉🎉点进来你就是我的人了
    博主主页:🙈🙈🙈戳一戳,欢迎大佬指点!

    欢迎志同道合的朋友一起加油喔🤺🤺🤺


    目录

    关于日志

    Spring Boot 日志的格式说明

     自定义打印日志

    日志级别

     日志持久化

    利用 lombok 来做到更简单的日志输出

    lombok 更多注解说明

    配置日志颜色:



    关于日志

    我们日常在写代码的时候,出现了异常,都会在编译器的控制台上,找出问题。这些问题并不是我们盲猜的,而是控制台上有明显的日志打印,我们就可以根据日志打印发现问题、解决问题。所以说,日志是调试程序重要的一环。

    此外,日志除了发现和定位问题外,它还有如下实用的功能:

    • 记录用户登录日志, 方便分析用户是正常登录还是恶意破解用户。
    • 记录系统的操作日志,方便数据恢复和定位操作人。
    • 记录程序的执行时间, 方便为以后优化程序提供数据支持。

    基于上面的介绍,本篇博客着重介绍 Spring Boot 提供的日志框架。

    Spring Boot 日志的格式说明

    我们发现在启动Spring Boot项目的时候,默认就有日志输出

     因为Spring Boot内置了日志框架SLF4Jlogback,默认的日志是打印在控制台上的

    那么,这些日志信息是什么意思呢?请看下图:

     自定义打印日志

    1. 得到日志对象(每个类都有自己的日志对象
    2. 使用日志对象提供的方法打印日志
    private static final Logger log = LoggerFactory.getLogger(TestController.class);
    

         这段代码定义了一个静态的Logger对象,用于记录TestController类的日志信息。LoggerFactory是一个日志框架,用于生成Logger对象。在这个例子中,log对象是一个私有的静态常量,只能在TestController类中使用。它的作用是记录TestController类的日志信息,以便在程序运行时进行调试和错误处理。

    1. @Controller
    2. @ResponseBody //加在类上, 表示当前类中的所有方法返回的都是非静态页面的数据
    3. public class TestController {
    4. private static final Logger log = LoggerFactory.getLogger(TestController.class);
    5. @RequestMapping ("/sayHi") // = WebServlet("/URL")
    6. public String sayHi() {
    7. log.trace("i'm trace");
    8. log.warn("i'm warn");
    9. log.debug("i'm debug");
    10. log.info("i'm info");
    11. log.error("i'm error");
    12. return "hello world ";
    13. }
    14. }

      打印结果:

     发现只打印了info,warn和error,因为日志的默认级别是info,只能打印它与比它更大级别的日志,trace和dubug的级别不够

    日志级别

    日志级别可以帮助我们筛选信息,从而节省程序员筛选日志的时间,日志级别可以控制不同环境下,打印日志的详细程度,如开发环境我们需要详细的日志信息,而线上环境我们为了性能,就打印少量的日志

    • trace:级别最低
    • debug:调试级别的,常用于跟踪程序的进展
    • info:普通的打印信息(默认的日志级别)
    • warn:警告级别,不影响使用,但应该注意
    • error:错误级别,错误日志信息打印
    • fatal:致命级别,因代码异常导致程序退出,级别最高

    日志的级别越高,打印的日志信息就越少

    六种日志级别,由低到高,越往级别高的日志,接收到的信息越少。

    比方说:

    当你的日志级别设置为 info 的时候,你只能看到 info、warn、error、fatal.
    当你的日志级别设置为 error 的时候,你只能看到 error、fatal.

    这很好理解,假设你的项目出现了异常,那么它优先显示错误的日志,因为正常的数据信息与你无关,你也不会对正常的代码进行排查。

    那如何设置日志的打印级别呢?

    在配置文件里,添加系统配置项 logging.level (application.yml配置文件写法)

    1. logging:
    2. level:
    3. #设置全局的日志级别
    4. root: error
    5. #指定包下的日志打印级别
    6. com.example.demo: warn

    当我们同时设置了全局日志和局部日志,那么,指定的局部目录的优先级就会大于全局日志的优先级。 (application.properties配置文件写法)

    1. # 设置全局的日志级别
    2. logging.level.root=error
    3. # 设置局部目录的日志级别
    4. logging.level.com.example.demo=warn

     日志持久化

    上面的日志打印都只是打印在控制台,但是线上我们一般都把日志持久化到文件中,以此方便日后排查问题

    日志持久化保存有以下两种方式:

    1. 设置日志的保存路径
    2. 设置日志的保存名称
    1. # 设置日志持久化保存的目录
    2. logging:
    3. file:
    4. path: D:\\log
    1. # 设置日志持久化保存的文件名称
    2. logging:
    3. file:
    4. name: D:\\log\\springboot.log

    运行程序后,会在本地生成一个日志文件,该日志文件是追加写的方式,即重启程序时,日志内容不会消失,也不会覆盖,而是追加写

     日志文件的大小默认是10MB,如果超过此大小,会重新创建一个文件保存新日志,可以通过系统配置项来设置这个文件的大小

    1. # 设置日志文件大小的最大值
    2. logging:
    3. logback:
    4. rollingpolicy:
    5. max-file-size: 50MB

    利用 lombok 来做到更简单的日志输出

    每次都使用LoggerFactory.getLogger(xxx.class) 获取日志对象,然后使用对象调用方法比较繁琐,因为每个类都要进行相同的操作,我们可以简化上述操作,使用如下操作方式:

    • 添加lombok依赖

    可以通过前面介绍的插件EditStarters添加lombok依赖,也可以手动添加

    1. <dependency>
    2. <groupId>org.projectlombokgroupId>
    3. <artifactId>lombokartifactId>
    4. <version>1.18.20version>
    5. <optional>trueoptional>
    6. dependency>
    • 在类上添加 @Slf4j 注解后,在类中就可以直接使用log对象
    1. @Slf4j
    2. public class LogController {
    3. public void writeLog(){
    4. log.info("write log"); //添加注解后,就有了log对象
    5. }
    6. }

    lombok的原理

     Java 程序的运行原理:

    Lombok 的作用如下图所示:

    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

    配置日志颜色:

    以下是配置日志颜色的一些好处:

    1. 可读性:彩色日志比黑白日志更容易阅读,特别是当日志量很大的时候。

    2. 高亮重要信息:错误和警告通常比其他信息更重要,用颜色高亮这些信息可以帮助你快速定位问题。

    3. 区分不同级别的日志:用不同的颜色表示不同级别的日志,可以帮助你了解每条日志信息的重要程度。

    4. 美观:彩色日志看起来比黑白日志更美观,更容易吸引人的注意。

    在application.properties文件里面添加一下配置即可:

    1. logging.level.root=INFO
    2. logging.pattern.console=%green([%d{yyyy-MM-dd HH:mm:ss.SSS}]) %cyan(%thread) %highlight(%-5level) %magenta(%logger{36}) %yellow(%L) - %white(%msg%n)

    效果如下图: 

    如果你觉得这篇文章有价值,或者你喜欢它,那么请点赞并分享给你的朋友。你的支持是我创作更多有用内容的动力,感谢你的阅读和支持。祝你有个美好的一天!"

  • 相关阅读:
    .NET 6 数组拷贝性能对比
    239.滑动窗口的最大值
    开箱即用,你不可错过的好东西「GitHub 热点速览」
    js的算法-交换排序(冒泡)
    《网络安全笔记》第十章:数据的封装和解封装
    Java学习笔记42——方法引用
    Android——Theme和Style-由浅入深,全面讲解
    设计模式-代理模式
    浮点数存储规则
    深度学习基础 2D卷积(1)
  • 原文地址:https://blog.csdn.net/m0_53882348/article/details/131138992