SpringBoot集成slf4j进行日志记录

 更新时间:2025年12月30日 08:46:32   作者:真实数据  
本文介绍了如何在Spring Boot中集成SLF4J进行日志记录,首先在yml文件中配置日志级别,然后创建logback.xml文件进行日志配置,在需要打印日志的地方,使用LoggerFactory获取Logger对象,并使用占位符进行日志信息的打印,感兴趣的朋友跟随小编一起看看吧

使用非常简单,在需要打印或者查看日志的情况下,可以采用这种打印,比sout直接输出要省性能。

1.首先在yml文件中配置

spring:
logging:
  config: logback.xml
  level:
    com.itcodai.course03.dao: trace

常用的日志级别按照从高到低依次为:ERROR、WARN、INFO、DEBUG。

上面这个日志级别是将sql语句打印出来

2.然后在springboot配置文件中加一个logback.xml文件,叫啥无所谓自己指定就行

<configuration>
    <property name="LOG_PATTERN" value="%date{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n" />
    <property name="FILE_PATH" value="D:/logs/course03/demo.%d{yyyy-MM-dd}.%i.log" />
<appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
    <encoder>
        <!-- 按照上面配置的LOG_PATTERN来打印日志 -->
        <pattern>${LOG_PATTERN}</pattern>
    </encoder>
</appender>
    <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!-- 按照上面配置的FILE_PATH路径来保存日志 -->
            <fileNamePattern>${FILE_PATH}</fileNamePattern>
            <!-- 日志保存15天 -->
            <maxHistory>15</maxHistory>
            <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                <!-- 单个日志文件的最大,超过则新建日志文件存储 -->
                <maxFileSize>10MB</maxFileSize>
            </timeBasedFileNamingAndTriggeringPolicy>
        </rollingPolicy>
        <encoder>
            <!-- 按照上面配置的LOG_PATTERN来打印日志 -->
            <pattern>${LOG_PATTERN}</pattern>
        </encoder>
    </appender>
    <logger name="com.itcodai.course03" level="INFO" />
    <root level="INFO">
        <appender-ref ref="CONSOLE" />
        <appender-ref ref="FILE" />
    </root>
</configuration>

3.在需要使用的地方,private final static Logger logger = LoggerFactory.getLogger(TestController.class);

  private static final Logger logger = LoggerFactory.getLogger(Test.class);
    @Test
    public void er(){
        int i=10;
        logger.debug("=====测试日志debug级别打印====");
        logger.info("======测试日志info级别打印=====");
        logger.error("=====测试日志error级别打印====");
        logger.warn("======测试日志warn级别打印=====");
        // 可以使用占位符打印出一些参数信息
        String str1 = "blog.itcodai.com";
        String str2 = "blog.csdn.net/eson_15";
        logger.info("======测试:{}", str1);
        logger.info("测试:{}",i);
    }

打印信息为

20:06:20.561 [main] INFO  org.junit.jupiter.api.Test - ======测试日志info级别打印=====
20:06:20.563 [main] ERROR org.junit.jupiter.api.Test - =====测试日志error级别打印====
20:06:20.563 [main] WARN  org.junit.jupiter.api.Test - ======测试日志warn级别打印=====
20:06:20.563 [main] INFO  org.junit.jupiter.api.Test - ======测试:blog.itcodai.com
20:06:20.564 [main] INFO  org.junit.jupiter.api.Test - 测试:10

打印其他信息需要有占位符{}。

到此这篇关于SpringBoot集成slf4j的文章就介绍到这了,更多相关SpringBoot集成slf4j内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Java高并发中的交换器Exchanger解析

    Java高并发中的交换器Exchanger解析

    这篇文章主要介绍了Java高并发中的交换器Exchanger解析,如果两个线程并行处理,但在某个时刻需要互相交换自己已经处理完的中间数据,然后才能继续往下执行,这个时候就可以使用 Exchanger,需要的朋友可以参考下
    2023-12-12
  • Java实现读取不同格式的文件的示例详解

    Java实现读取不同格式的文件的示例详解

    在 Java 开发中,我们经常需要读取不同类型的文件,包括 Excel 表格文件、"doc" 等,本文将介绍如何使用 Java 读取这些不同类型的文件,需要的可以参考下
    2024-01-01
  • spring-session自定义序列化方式

    spring-session自定义序列化方式

    这篇文章主要介绍了spring-session自定义序列化方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-12-12
  • javamail 发送邮件的实例代码分享

    javamail 发送邮件的实例代码分享

    今天学习了一下JavaMail,javamail发送邮件确实是一个比较麻烦的问题。为了以后使用方便,自己写了段代码,打成jar包,以方便以后使用
    2013-08-08
  • mybatis plus的3种查询方式(小结)

    mybatis plus的3种查询方式(小结)

    这篇文章主要介绍了mybatis plus的3种查询方式(小结),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • 详解Java中的静态代理模式

    详解Java中的静态代理模式

    这篇文章主要为大家介绍了Java中的静态代理模式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2022-12-12
  • java高并发的ReentrantLock重入锁

    java高并发的ReentrantLock重入锁

    这篇文章主要介绍了如何教你完全理解ReentrantLock重入锁,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,下面我们来一起学习一下吧
    2021-10-10
  • 从零开始学JAVA之可变参数

    从零开始学JAVA之可变参数

    本文是从零开始学JAVA的第一篇,属于Java基础知识介绍的第一部分,主要介绍Java的可变参数,非常使用,希望对大家有所帮助
    2014-10-10
  • 浅谈Java 中的单元测试

    浅谈Java 中的单元测试

    这篇文章主要介绍了Java 中的单元测试的相关资料,帮助大家更好的理解和使用Java,感兴趣的朋友可以了解下
    2020-09-09
  • springboot整合websocket实现群聊思路代码详解

    springboot整合websocket实现群聊思路代码详解

    通过springboot引入websocket,实现群聊,通过在线websocket测试进行展示。本文重点给大家介绍springboot整合websocket实现群聊功能,代码超级简单,感兴趣的朋友跟随小编一起学习吧
    2021-05-05

最新评论