码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Spring Boot整合日志


    ✨Spring Boot整合日志

    • 1.日志框架概述
    • 2.slf4j(Spring Boot底层默认整合slf4j)
    • 3.日志全局配置
      • 3.1配置日志级别(默认是info)
      • 3.2配置日志的输出格式
      • 3.3配置日志文件的输出位置
    • 4.logback配置文件(Spring Boot日志的实现层默认使用logback)
      • 4.1全局配置文件中,设置logback配置文件路径
      • 4.2logback配置
    • 5.整合Lombok
      • 5.1概述
      • 5.2插件安装
      • 5.3Lombok的使用

    📃个人主页: 不断前进的皮卡丘
    🌞博客描述: 梦想也许遥不可及,但重要的是追梦的过程,用博客记录自己的成长,记录自己一步一步向上攀登的印记
    🔥网站推荐:千里之行,始于足下。每天坚持刷题,巩固所学知识,也为将来找工作,面试做好准备----- 刷题神器

    1.日志框架概述

    • 市面上常见的日志框架有很多,它们可以被分为两类:日志门面(日志抽象层)和日志实现

    • 通常情况下,日志由一个日志门面与一个日志实现组合搭建而成,Spring Boot 选用 SLF4J + Logback 的组合来搭建日志系统。

    • SLF4J 是目前市面上最流行的日志门面,使用 Slf4j 可以很灵活的使用占位符进行参数占位,简化代码,拥有更好的可读性。

    • Logback 是 Slf4j 的原生实现框架,它与 Log4j 出自一个人之手,但拥有比 log4j 更多的优点、特性和更做强的性能,现在基本都用来代替 log4j 成为主流。

    • 在这里插入图片描述

    2.slf4j(Spring Boot底层默认整合slf4j)

    1️⃣slf4j(Simple Logging Facade for java)中文意思是简单日志门面,是获取日志的标标准接口。
    2️⃣slf4j的官网地址:https://www.slf4j.org/
    3️⃣slf4j的日志级别分为:trace 在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

    3.日志全局配置

    3.1配置日志级别(默认是info)

    在这里插入图片描述
    在这里插入图片描述

    3.2配置日志的输出格式

    在这里插入图片描述

    在这里插入图片描述

    3.3配置日志文件的输出位置

    在这里插入图片描述
    我们可以看到在D盘确实可以找到对应的日志文件的输出位置,而且日志信息是追加的在这里插入图片描述

    4.logback配置文件(Spring Boot日志的实现层默认使用logback)

    这里简单了解一下就可以
    除了全局配置文件配置日志以外,我们也可以单独配置日志文件,比如logback的配置如下:

    4.1全局配置文件中,设置logback配置文件路径

    # 激活开发环境
    spring.profiles.active=dev
    # 设置日志配置文件位置
    logging.config=classpath:logback-config.xml
    
    • 1
    • 2
    • 3
    • 4

    4.2logback配置

    logback的使用

    5.整合Lombok

    5.1概述

    • Lombok简化了实体类中大量的getter/setter、toString、hashCode、equals等方法
    • 在运行过程中,Lombok自动生成相应方法
    • Lombok通过注解的方法,注入了日志对象log
    • 官网地址:https://www.projectlombok.org/

    5.2插件安装

    在这里插入图片描述

    5.3Lombok的使用

    在创建Spring Boot项目的时候,勾选Lombok
    在这里插入图片描述
    然后构建项目的时候,会自动在pom.xml中添加lombok依赖
    在这里插入图片描述
    在这里插入图片描述
    如果我们相要使用有参构造的话,这个时候是不可以的,因为没有提供对应的有参构造方法,为了解决这个情况,我们可以使用注解

    @Data
    @AllArgsConstructor  //帮我们生成有参构造
    @Component
    public class Book {
        private String name;
        private Double price;
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    但是,我们也可以发现,使用@AllArgsConstructor提供了有参构造后,无参构造就不会创建,但是有时候我们是需要使用无参构造,比如说实体类在spring容器中的自动注入就必须提供无参构造
    @NoArgsConstructor可以提供无参构造
    @AllArgsConstructor可以提供有参构造
    在这里插入图片描述
    在这里插入图片描述

  • 相关阅读:
    用爬虫代码爬取高音质音频示例
    21天学习挑战赛-静态链表以及一个带头结点的 线性链表类型 的定义
    NetworkManger 报错 “NIC: Link is Down“
    浅谈矩阵 学习笔记
    VisionPro学习笔记(3)——BeadInspectTool
    HTML期末学生大作业:中华传统文化【苏绣手工艺】带psd设计图(15页)
    企业数字化转型需要深入研究,不能为了转型而转型
    PAT 1035 Password
    vivado 仿真读写bmp图片
    Vue获取url路由地址、参数
  • 原文地址:https://blog.csdn.net/qq_52797170/article/details/126079675
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号