欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

SpringBoot输出日志到文件

程序员文章站 2022-09-27 09:21:59
1 基本信息 SpringBoot版本2.2.5 日志框架SLF4J 日志框架的实现LockBack 2 输出文件的配置 2.1 logging.file.name 指定日志文件的位置。 2.1.1 例1 使用相对路径,就会在项目根目录下生成一个lab.log文件 2.1.1 例2 在项目根目录下生 ......

1 基本信息

  • springboot版本2.2.5
  • 日志框架slf4j
  • 日志框架的实现lockback

2 输出文件的配置

2.1 logging.file.name

指定日志文件的位置。

2.1.1 例1

使用相对路径,就会在项目根目录下生成一个lab.log文件

logging:
  file:
    name: lab.log

2.1.1 例2

在项目根目录下生成一个logs文件夹,logs文件夹里面生成一个lab.log文件。

logging:
  file:
    name: logs/lab.log

2.1.1 例3

使用绝对路径,这样写会在d盘下创建一个logs文件夹,logs文件夹里面生成一个lab.log文件。

logging:
  file:
    name: d:/logs/lab.log

2.2 logging.file.path

2.2.1 指定路径时生成的文件名为spring.log

2.2.2 例1

使用相对路径,会在项目根目录下生成一个logs文件夹,logs文件夹会有一个spring.log文件。

logging:
  file:
    path: logs

2.2.2 例2

使用绝对路径,会在d盘下生成一个logs文件夹,logs文件夹会有一个spring.log文件。

logging:
  file:
    name: d:/logs

2.3 注意

logging.file.name和logging.file.path不要同时指定,只需要指定一个。

相对路径不指定盘符,直接在项目根目录下生成

3 使用xml扩展

在resources目录下创建logback-spring.xml配置文件。

使用xml配置可以完成yml配置实现不了的功能,比如按天将日志归档。

xml有多种命名形式,但官方推荐的命名是logback-spring.xml

<?xml version="1.0" encoding="utf-8"?>
<configuration scan="true" scanperiod="60 seconds" debug="false">
    <contextname>logback</contextname>

    <!--控制台输出内容的颜色转换以及格式-->
    <substitutionproperty name="logging.pattern.console"
                          value="%clr(%d{${log_dateformat_pattern:-yyyy-mm-dd hh:mm:ss.sss}}){faint} %clr(${log_level_pattern:-%5p}) %clr(${pid:- }){magenta} %clr(---){faint} %clr([%15.15t]){faint} %clr(%-40.40logger{39}){cyan} %clr(:){faint} %m%n${log_exception_conversion_word:-%wex}"/>
    <!--日志文件输出内容的格式-->
    <substitutionproperty name="logging.pattern.file"
                          value="%d{${log_dateformat_pattern:-yyyy-mm-dd hh:mm:ss.sss}} ${log_level_pattern:-%5p} ${pid:- } --- [%t] %-40.40logger{39} : %m%n${log_exception_conversion_word:-%wex}"/>

    <conversionrule conversionword="clr" converterclass="org.springframework.boot.logging.logback.colorconverter"/>
    <conversionrule conversionword="wex"
                    converterclass="org.springframework.boot.logging.logback.whitespacethrowableproxyconverter"/>
    <conversionrule conversionword="wex"
                    converterclass="org.springframework.boot.logging.logback.extendedwhitespacethrowableproxyconverter"/>

    <!--输出到控制台-->
    <appender name="console" class="ch.qos.logback.core.consoleappender">
        <!--控制台使用layout节点-->
        <layout class="ch.qos.logback.classic.patternlayout">
            <pattern>
                ${logging.pattern.console}
            </pattern>
        </layout>
    </appender>

    <!--按天生成日志-->
    <appender name="file" class="ch.qos.logback.core.rolling.rollingfileappender">
        <prudent>true</prudent>
        <!--滚动策略,我配置了按天生成日志文件-->
        <rollingpolicy class="ch.qos.logback.core.rolling.timebasedrollingpolicy">
            <!--相对路径,生成的文件就在项目根目录下-->
            <filenamepattern>
                logs/%d{yyyy-mm}/%d{yyyy-mm-dd}.log
            </filenamepattern>
            <!--注意超过365天的日志文件会被删除,即使已经按天分开也会删除-->
            <maxhistory>365</maxhistory>
        </rollingpolicy>
        <!--日志文件里只保存error及以上级别的日志-->
        <filter class="ch.qos.logback.classic.filter.thresholdfilter">
            <level>error</level>
        </filter>
        <!--文件使用encoder节点-->
        <encoder>
            <pattern>
                ${logging.pattern.file}
            </pattern>
        </encoder>
    </appender>

    <!--这个logger里的配置相当于之前yml里的logging.level.com.lpc: trace-->
    <!--additivity的作用-->
    <!--true,则子logger不止会在自己的appender里输出,还会在root的logger的appender里输出-->
    <!--而这个logger里没配置appender,所以得交给root打印-->
    <!--所以com.lpc包里的日志从trace级别开始-->
    <!--其他包里的日志根据root的配置从info级别开始打印-->
    <logger name="com.lpc" level="trace" additivity="true">
    </logger>

    <root level="info">
        <appender-ref ref="console"/>
        <appender-ref ref="file"/>
    </root>

</configuration>

其中,两个的value属性是yml的logging.pattern.console和logging.pattern.file的默认值粘贴出来的。xml文件放在了resources.config目录下。日志文件输出在项目根目录下的logs文件夹下。

这个xml配置实现了:

  1. 控制台输出日志,同时将日志保存到文件里;
  2. 保持控制台日志的彩色;
  3. 按月建日志文件夹,按天建日志文件;
  4. com.lpc包下的日志从trace级别开始输出,其他包(比如tomcat的日志,springsecurity的日志)从info级别开始输出。跟原来yml里面配置logging.level.com.lpc: trace的输出结果保持一致。

4 logging里的默认值

logging.pattern.console

%clr(%d{${log_dateformat_pattern:-yyyy-mm-dd hh:mm:ss.sss}}){faint} %clr(${log_level_pattern:-%5p}) %clr(${pid:- }){magenta} %clr(---){faint} %clr([%15.15t]){faint} %clr(%-40.40logger{39}){cyan} %clr(:){faint} %m%n${log_exception_conversion_word:-%wex}

logging.pattern.file

%d{${log_dateformat_pattern:-yyyy-mm-dd hh:mm:ss.sss}} ${log_level_pattern:-%5p} ${pid:- } --- [%t] %-40.40logger{39} : %m%n${log_exception_conversion_word:-%wex}

5 效果

SpringBoot输出日志到文件

本文由博客群发一文多发等运营工具平台 openwrite 发布