当前位置: 移动技术网 > IT编程>开发语言>Java > SpringBoot输出日志到文件

SpringBoot输出日志到文件

2020年04月14日  | 移动技术网IT编程  | 我要评论

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 效果

效果.png

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

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网