詳解Spring Boot配置使用Logback進行日志記錄的實戰(zhàn)
spring Boot實戰(zhàn)之配置使用Logback進行日志記錄 ,分享給大家
在這篇文章中我們將討論在Spring Boot中使用Logback,在Spring Boot中使用Logback很簡單
1、為了測試我們新建兩個類
package com.xiaofangtech.sunt.controller;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import com.xiaofangtech.sunt.helper.LogHelper;
@RestController
@RequestMapping("log")
public class LogController {
private final Logger logger = LoggerFactory.getLogger(this.getClass());
@RequestMapping("writelog")
public Object writeLog()
{
logger.debug("This is a debug message");
logger.info("This is an info message");
logger.warn("This is a warn message");
logger.error("This is an error message");
new LogHelper().helpMethod();
return "OK";
}
}
package com.xiaofangtech.sunt.helper;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class LogHelper {
private final Logger logger = LoggerFactory.getLogger(this.getClass());
public void helpMethod(){
logger.debug("This is a debug message");
logger.info("This is an info message");
logger.warn("This is a warn message");
logger.error("This is an error message");
}
}
2、運行,在瀏覽器中輸入http://localhost:8080/log/writelog 將會看到以下結果

我們沒有配置任何其它配置,就可以看到來自logback root logger的輸出信息。雖然默認情況下logback是會打印debug級別的日志,但是我們注意到debug級別的日志沒有記錄下來,那是因為Spring Boot為Logback提供了默認的配置文件,base.xml,另外Spring Boot 提供了兩個輸出端的配置文件console-appender.xml和file-appender.xml,base.xml引用了這兩個配置文件。

以下是base.xml的內(nèi)容,我們可以看到,root logger的日志級別被重寫為Info級別,這就是上面例子中debug級別的日志沒有打印的原因
<?xml version="1.0" encoding="UTF-8"?>
<!--
Base logback configuration provided for compatibility with Spring Boot 1.1
-->
<included>
<include resource="org/springframework/boot/logging/logback/defaults.xml" />
<property name="LOG_FILE" value="${LOG_FILE:-${LOG_PATH:-${LOG_TEMP:-${java.io.tmpdir:-/tmp}}/}spring.log}"/>
<include resource="org/springframework/boot/logging/logback/console-appender.xml" />
<include resource="org/springframework/boot/logging/logback/file-appender.xml" />
<root level="INFO">
<appender-ref ref="CONSOLE" />
<appender-ref ref="FILE" />
</root>
</included>
3、通過application.properties文件對Logback進行配置

logging.file=log.log logging.level.com.xiaofangtech.sunt.controller = debug logging.level.com.xiaofangtech.sunt.helper = warn
配置記錄日志到log.log,com.xiaofangtech.sunt.controller日志級別為debug,.com.xiaofangtech.sunt.helper中日志級別為warn
我們將會看到以下結果,按照配置的日志級別進行記錄。

并且可以看到日志記錄到了日志文件中

4、通過額外的文件配置Logback
通過application.properties文件配置Logback,對于大多數(shù)Spring Boot應用來說已經(jīng)足夠了,但是對于一些大型的企業(yè)應用來說似乎有一些相對復雜的日志需求。在Spring Boot中你可以在logback.xml或者在logback-spring.xml中對Logback進行配置,相對于logback.xml,logback-spring.xml更加被偏愛。下面我們以logback-spring.xml為例。
新建logback-spring.xml,配置輸出的日志都為warn級別
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<include resource="org/springframework/boot/logging/logback/base.xml"/>
<logger name="com.xiaofangtech.sunt.controller" level="WARN" additivity="false">
<appender-ref ref="CONSOLE"/>
<appender-ref ref="FILE"/>
</logger>
<logger name="com.xiaofangtech.sunt.helper" level="WARN" additivity="false">
<appender-ref ref="CONSOLE"/>
<appender-ref ref="FILE"/>
</logger>
</configuration>
運行結果如下:

本文參考:https://springframework.guru/using-logback-spring-boot/
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- IDEA?設置?SpringBoot?logback?彩色日志的解決方法?附配置文件
- Springboot使用Logback實現(xiàn)日志配置與異常記錄
- SpringBoot項目的logback日志配置(包括打印mybatis的sql語句)
- Spring Boot日志技術logback原理及配置解析
- springboot配置logback日志管理過程詳解
- 基于logback 實現(xiàn)springboot超級詳細的日志配置
- spring boot使用logback實現(xiàn)多環(huán)境日志配置詳解
- 詳解Spring Boot 使用slf4j+logback記錄日志配置
- 如何為?Spring?Boot?項目配置?Logback?日志
相關文章
使用IDEA配置Tomcat和連接MySQL數(shù)據(jù)庫(JDBC)詳細步驟
這篇文章主要介紹了使用IDEA配置Tomcat和連接MySQL數(shù)據(jù)庫(JDBC)詳細步驟,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-12-12
Spring session實現(xiàn)Session共享
本文主要介紹了Spring session實現(xiàn)Session共享,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-04-04
Java數(shù)據(jù)結構之堆(優(yōu)先隊列)的實現(xiàn)
堆(優(yōu)先隊列)是一種典型的數(shù)據(jù)結構,其形狀是一棵完全二叉樹,一般用于求解topk問題。本文將利用Java語言實現(xiàn)堆,感興趣的可以學習一下2022-05-05

