码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • SpringBoot日志文件


    目录

    • SpringBoot日志文件
      • 日志的作用
      • 日志的使用
        • 默认日志打印
        • 自定义日志打印
      • 日志级别
      • 日志持久存储
      • 更便捷的日志输出——Lombok

    SpringBoot日志文件

    日志的作用

    日志是调试程序的重要参考,一个程序中的大部分bug都可以通过日志找到.因此日志对于程序而言是一个非常重要的组成部分
    日志的主要功能有:

    1. 发现和定位问题
    2. 记录用户登录日志,便于分析用户的登录属于正常登陆还是恶意破解
    3. 记录系统的操作日志,方便数据恢复
    4. 记录程序的执行时间,方便后续对程序的优化作参考

    日志的使用

    默认日志打印

    在Spring Boot项目中,当我们启动项目时会有一系列默认日志输出在这里插入图片描述
    这些日志记录了Spring Boot启动时的一些信息,如版本,启动项目时长,端口号信息等等.

    自定义日志打印

    默认情况下输出的日志都是Spring Boot默认的一些日志.当我们由于实际需求需要自定义日志时,首先需要在程序中得到日志对象,然后使用日志对象输出对应的日志内容

    1. 获取日志对象
      使用日志工厂来找到对应类的日志对象
      在这里插入图片描述
      Logger类是org.slf4j包下的Logger接口在这里插入图片描述
    2. 使用日志对象打印日志内容
      使用日志对象的对应方法来打印日志
      在这里插入图片描述
      在这里插入图片描述

    日志级别

    日志级别是为了更快的定位目标日志,从而快速筛选出bug
    常用的日志级别可以分为6种:trace,debug,info,warn,error,fetal

    trace:级别最低的一种日志细腻
    debug:需要调试的时候的关键信息打印
    info:普通的打印信息
    warn:警告信息的打印
    error:错误信息的打印
    fetal:致命信息的打印
    日志级别从上到下依次增高

    日志级别的配置只需要在配置文件中添加logging.level.root=error/warn/info,默认的日志级别是info.

    日志持久存储

    默认情况下日志都是在控制台打印的,当日志内容比较多时,翻看控制台很不方便,而且控制台的信息会随着项目的重启而丢失,无法持久化存储.更好的方式是将日志打印到磁盘的文件中.
    方式就是在配置文件中添加日志文件的保存路径以及日志文件的文件名

    logging.file.path=F:/a/ #配置日志文件的保存路径
    logging.file.name=F: /a/spring-boot.log #配置日志文件的文件名

    更便捷的日志输出——Lombok

    在上述自定义日志打印时,我们需要通过日志工厂LoggingFactory来获取到对应类的日志对象.相较于这种方式,我们可以通过引入Lombok依赖,利用Lombok中的@Slf4j注解来获取日志对象

    1. 引入Lombok依赖
      在这里插入图片描述
    2. 添加@Slf4j注解并使用注解中的log对象
      在这里插入图片描述
      在这里插入图片描述

    尽管Lombok中使用的是@Slf4j对象,但在编译时会将@Slf4j中的log对象重新还原为日志工厂中中对应类型的日志对象在这里插入图片描述

  • 相关阅读:
    【vue】ant-design弹出框无法关闭和runtimecore提示isFucntion is not function的问题修复
    艾尔登法环约定之王拉塔恩打法
    GraphSAGE-pytorch-inductive
    HTML5学习笔记(三)
    基于PHP的校园二手信息网站的设计与实现毕业设计源码251656
    ​软考-高级-系统架构设计师教程(清华第2版)【第9章 软件可靠性基础知识(P320~344)-思维导图】​
    java---kruskal算法---最小生成树(2)(每日一道算法2022.9.3)
    vue-router当中内置component标签(组件)的使用
    华为机试 - 面试
    测试用例之使用测试方法
  • 原文地址:https://blog.csdn.net/weixin_52477733/article/details/126494619
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号