SpringBoot日志的使用解讀
SpringBoot默認(rèn)使用SLF4J作為日志門面(相當(dāng)于接口),Logback作為日志實(shí)現(xiàn)(實(shí)現(xiàn)可切換)
一.默認(rèn)輸出格式
1.日期時(shí)間
2.日志級別(從上至下級別越來越高):
TRACE
:追蹤框架流程日志,一般不使用DEBUG
:調(diào)試日志INFO
:關(guān)鍵、感興趣日志WARN
:警告日志ERROR
:錯(cuò)誤日志
3.進(jìn)程ID
4.---:消息分隔符
5.線程名:用[]包裹
6.Logger名:產(chǎn)生這條日志的類名
7.消息:具體日志內(nèi)容
二.使用
@Service public class UserService{//創(chuàng)建UserService類對應(yīng)的Logger(SLF4J包下) private Logger logger= LoggerFactory.getLogger(getClass()); public void useLogger() {//使用 Loggerlogger.trace("TRACE"); logger.debug("DEBUG"); logger.info("INFO {} {}", "參1", "參2"); logger.warn("WARN"); logger.error("ERROR"); }
導(dǎo)入lombok后使用@Slf4j注解,會自動創(chuàng)建變量名為log的Logger
只會輸出INFO及以上的日志級別,因?yàn)镾pringBoot默認(rèn)日志級別為INFO
三.配置
通過yml文件配置日志(以logging開頭的日志)
項(xiàng)目中通常不使用該方式
原因:
- 日志需要較多自定義,放yml里導(dǎo)致其他配置也難以閱讀
- yml提供的日志配置只支持logback實(shí)現(xiàn),切換實(shí)現(xiàn)后不可用
- yml提供的logback配置不夠全面
通過xml配置日志
appender
:負(fù)責(zé)寫日志的組件(輸出到控制臺、文件、日志服務(wù)器、消息隊(duì)列等等)appender-ref
:引用某個(gè)appenderlayout
:配置日志輸出格式springProfile
:配置日志在開發(fā)/測試/生產(chǎn)環(huán)境生效springProperty
:在xml配置中引用yml的配置值property
:在xml中定義值
logback-spring.xml模板示例
<?xml version="1.0" encoding="UTF-8"?> <configuration><!--讀取yml配置中的spring.application.name值賦值給FILE_NAME變量--> <springProperty scope="context" name="FILE_NAME" source="spring.application.name"/><!--定義FILE_PATH變量--> <property name="FILE_PATH" value="./logs"/> <springProfile name="dev"><!--開發(fā)環(huán)境的日志配置--> <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender"><!--輸出到控制臺--> <layout><!--設(shè)置日志格式--> <pattern>%d{yyyy-MM-dd HH:mm:ss}[%thread] %-5level %logger -%msg%n</pattern> </layout> </appender> <root level="info"><!--設(shè)置日志等級 及 生效appender--> <appender-ref ref="STDOUT"/> </root> </springProfile> <springProfile name="test"><!--測試環(huán)境的日志配置--> <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender"> <layout> <pattern>%d{yyyy-MM-dd HH:mm:ss}[%thread] %-5level %logger -%msg%n</pattern> </layout> </appender><!--輸出到文件,文件會根據(jù)日期、大小進(jìn)行歸檔--> <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender"> <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy"><!--文件路徑--> <fileNamePattern>${FILE_PATH}/${FILE_NAME}%d{yyyy-MM-dd}.%i.log</fileNamePattern> <maxHistory>30</maxHistory><!--文件保存天數(shù)--> <maxFileSize>10MB</maxFileSize><!--一個(gè)文件最大值--> </rollingPolicy> <layout> <pattern>%d{yyyy-MM-dd HH:mm:ss}[%thread] %-5level %logger -%msg%n</pattern> </layout> </appender> <root level="info"> <appender-ref ref="STDOUT"/> <appender-ref ref="FILE"/> </root> </springProfile> <springProfile name="prod"><!--生產(chǎn)環(huán)境的日志配置--> <appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender"> <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy"> <fileNamePattern>${FILE_PATH}/${FILE_NAME}%d{yyyy-MM-dd}.%i.log</fileNamePattern> <maxHistory>30</maxHistory> <maxFileSize>10MB</maxFileSize> </rollingPolicy> <layout> <pattern>%d{yyyy-MM-dd HH:mm:ss}[%thread] %-5level %logger -%msg%n</pattern> </layout> </appender> <root level="error"> <appender-ref ref="FILE"/> </root> </springProfile> </configuration>
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
SpringBoot實(shí)現(xiàn)多租戶架構(gòu)
在SpringBoot中可以通過多數(shù)據(jù)源和動態(tài)路由來實(shí)現(xiàn)多租戶機(jī)制,本文主要介紹了SpringBoot實(shí)現(xiàn)多租戶架構(gòu),具有一定的參考價(jià)值,感興趣的可以里哦啊接一下2024-03-03Java 8 Lambda 表達(dá)式比較器使用示例代碼
這篇文章主要介紹了Java 8 Lambda 表達(dá)式比較器使用示例代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-08-08springboot+mybatis報(bào)錯(cuò)找不到實(shí)體類的問題
這篇文章主要介紹了springboot+mybatis報(bào)錯(cuò)找不到實(shí)體類的問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01java 線程方法join簡單用法實(shí)例總結(jié)
這篇文章主要介紹了java 線程方法join簡單用法,結(jié)合實(shí)例形式總結(jié)分析了Java線程join方法的功能、原理及使用技巧,需要的朋友可以參考下2019-11-11SpringCloud中的@RefreshScope注解與使用場景方式
SpringCloud中的@RefreshScope注解用于動態(tài)刷新Bean配置,解決外部配置變化時(shí)的問題,避免重啟應(yīng)用,通過本文的詳細(xì)介紹,希望讀者能夠更好地掌握@RefreshScope的使用技巧,在實(shí)際項(xiàng)目中靈活應(yīng)用,提升微服務(wù)應(yīng)用的動態(tài)配置管理能力2024-12-12