乐趣区

关于java:springbootroute十六使用logback生产日志文件

日志是一个零碎十分重要的一部分,咱们常常须要通过查看日志来定位问题,明天咱们一起来学习一下 Spring Boot 的日志零碎。有很多同学习惯性的在生产代码中应用 System.out 来输入日志,这是不举荐的一种做法,因为 System.out 是一个同步操作,会在肯定水平上影响零碎性能,而 Logger 是一个异步操作。

Spring Boot 默认的日志零碎是 logback,当然咱们并不需要去援用logback 的依赖,因为在 spring-boot-starter 中曾经利用了 logback 的依赖。

一、控制台日志信息介绍

1.1 日志级别

日志级别从高到低为:TRACE < DEBUG < INFO < WARN < ERROR < ALL < OFF

如果日志设置为 ERROR,那么低于ERROR 级别的日志将不会输入。

如果咱们想要设置某个包的日志级别,则在 pom 文件中退出上面这行配置:

logging:
  level:
      # 包名
    com.javatrip: warn

如果想批改 Spring Boot 默认级别,则将包名改为root

logging:
  level:
    root: warn

1.2 控制台日志介绍

默认状况下,Spring Boot 会将 INFO 级别的日志输入到控制台。控制台输入信息如下:

日志输入内容具体含意如下:

  • 工夫日期:准确到毫秒
  • 日志级别:ERROR, WARN, INFO, DEBUG or TRACE
  • 过程 ID
  • 分隔符:--- 标识理论日志的开始
  • 线程名:方括号括起来(可能会截断控制台输入)
  • Logger 名:通常应用源代码的类名
  • 日志内容

二、日志文件输入

在理论我的项目中,咱们须要将日志输入为文件,以便疾速定位问题。Spring Boot 对于日志文件的信息能够参考官网https://docs.spring.io/spring-boot/docs/current/reference/htmlsingle/#boot-features-logging

Because the standard logback.xml configuration file is loaded too early, you cannot use extensions in it. You need to either use logback-spring.xml or define a logging.config property.

这句话的意思大略就是:因为规范的 logback.xml 配置文件加载得太早,因而您不能在其中应用扩展名。您须要应用 logback-spring.xml 或定义 logging.config 属性。

因而咱们来定义一个 logback-spring.xml 的文件来进行日志信息的配置。

logback-spring.xml文件定义及正文:

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
    <!-- 日志文件名 -->
    <property name="LOG_FILE" value="myLog" />
    <!-- 日志文件门路 -->
    <property name="LOG_PATH" value="D://log//dev" />
    <!-- 控制台日志输入格局 -->
    <property name="LOG_PATTERN_CONSOLE" value="%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{50} --> %msg%n" />
    <!-- 文件日志输入格局 -->
    <property name="LOG_PATTERN_FILE" value="%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{50} --> %msg%n" />
    <!--- 设置控制台日志 -->
    <appender name="consoleLog" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <pattern>${LOG_PATTERN_CONSOLE}</pattern>
        </encoder>
    </appender>
    <!-- 设置日志文件 -->
    <appender name="fileLog" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <encoder>
            <pattern>${LOG_PATTERN_FILE}</pattern>
        </encoder>
        <!-- 总文件日志 -->
        <file>${LOG_PATH}/${LOG_FILE}.log</file>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!-- 每天的文件日志 -->
            <fileNamePattern>${LOG_PATH}/${LOG_FILE}-%d{yyyy-MM-dd}.log</fileNamePattern>
            <!-- 日志文件保留 7 天,超过 7 天的主动删除 -->
            <maxHistory>7</maxHistory>
        </rollingPolicy>
    </appender>

    <!-- 设置日志级别,及须要记录日志的类 -->
    <root level="INFO">
        <appender-ref ref="consoleLog" />
        <appender-ref ref="fileLog" />
    </root>
</configuration>

启动我的项目后,在 D:\log\dev 中会生产咱们的日志文件 myLog.log,退出咱们零碎始终运行,则在咱们的文件目录下会生成一个myLog.log 文件和 7 个最近日志的文件myLog- 某年 - 某月 - 某日.log

此是 spring-boot-route 系列的第十六篇文章,这个系列的文章都比较简单,次要目标就是为了帮忙首次接触 Spring Boot 的同学有一个零碎的意识。本文已收录至我的 github,欢送各位小伙伴star

github:https://github.com/binzh303/s…

点关注、不迷路

如果感觉文章不错,欢送 关注 点赞 珍藏,你们的反对是我创作的能源,感激大家。

如果文章写的有问题,请不要悭吝,欢送留言指出,我会及时核查批改。

如果你还想更加深刻的理解我,能够微信搜寻「Java 旅途」进行关注。回复「1024」即可取得学习视频及精美电子书。每天 7:30 准时推送技术文章,让你的下班路不在孤单,而且每月还有送书流动,助你晋升硬实力!

退出移动版