spring-boot-route(十六)使用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


本文示例代碼已上傳至github,點個star支持一下!

Spring Boot系列教程目錄

spring-boot-route(一)Controller接收參數的幾種方式

spring-boot-route(二)讀取配置文件的幾種方式

spring-boot-route(三)實現多文件上傳

spring-boot-route(四)全局異常處理

spring-boot-route(五)整合swagger生成接口文檔

spring-boot-route(六)整合JApiDocs生成接口文檔

spring-boot-route(七)整合jdbcTemplate操作數據庫

spring-boot-route(八)整合mybatis操作數據庫

spring-boot-route(九)整合JPA操作數據庫

spring-boot-route(十)多數據源切換

spring-boot-route(十一)數據庫配置信息加密

spring-boot-route(十二)整合redis做為緩存

spring-boot-route(十三)整合RabbitMQ

spring-boot-route(十四)整合Kafka

spring-boot-route(十五)整合RocketMQ

spring-boot-route(十六)使用logback生產日志文件

spring-boot-route(十七)使用aop記錄操作日志

spring-boot-route(十八)spring-boot-adtuator監控應用

spring-boot-route(十九)spring-boot-admin監控服務

spring-boot-route(二十)Spring Task實現簡單定時任務

spring-boot-route(二十一)quartz實現動態定時任務

spring-boot-route(二十二)實現郵件發送功能

spring-boot-route(二十三)開發微信公眾號

spring-boot-route(二十四)分布式session的一致性處理

spring-boot-route(二十五)兩行代碼實現國際化

spring-boot-route(二十六)整合webSocket

這個系列的文章都是工作中頻繁用到的知識,學完這個系列,應付日常開發綽綽有余。如果還想了解其他內容,掃面下方二維碼告訴我,我會進一步完善這個系列的文章!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM