SpringBoot使用Commons Logging進行所有內部日志記錄,但保留底層日志實現。默認提供了Java Util Logging, Log4j2 和Logback日志配置。在每種情況下,都預先配置為使用控制臺輸出,并且還提供了可選的文件輸出。(來自官網)
創新互聯服務項目包括江津網站建設、江津網站制作、江津網頁制作以及江津網絡營銷策劃等。多年來,我們專注于互聯網行業,利用自身積累的技術優勢、行業經驗、深度合作伙伴關系等,向廣大中小型企業、政府機構等提供互聯網行業的解決方案,江津網站推廣取得了明顯的社會效益與經濟效益。目前,我們服務的客戶以成都為中心已經輻射到江津省份的部分城市,未來相信會繼續擴大服務區域并繼續獲得客戶的支持與信任!
日志格式
SpringBoot默認的日志輸出如下所示:
2014-03-05 10:57:51.112 INFO 45469 --- [ main] org.apache.catalina.core.StandardEngine : Starting Servlet Engine: Apache Tomcat/7.0.52 2014-03-05 10:57:51.253 INFO 45469 --- [ost-startStop-1] o.a.c.c.C.[Tomcat].[localhost].[/] : Initializing Spring embedded WebApplicationContext 2014-03-05 10:57:51.253 INFO 45469 --- [ost-startStop-1] o.s.web.context.ContextLoader : Root WebApplicationContext: initialization completed in 1358 ms 2014-03-05 10:57:51.698 INFO 45469 --- [ost-startStop-1] o.s.b.c.e.ServletRegistrationBean : Mapping servlet: 'dispatcherServlet' to [/] 2014-03-05 10:57:51.702 INFO 45469 --- [ost-startStop-1] o.s.b.c.embedded.FilterRegistrationBean : Mapping filter: 'hiddenHttpMethodFilter' to: [/*]
輸出以下項目:
Logback中沒有FATAL(致命)級別,它被映射到ERROR級別
( 日志格式來自 官網 )
控制臺輸出
SpringBoot控制臺輸出默認支持三種日志級別:ERROR,WARN和INFO
如果還想輸出別的級別日志,例如DEBUG或TRACE(只能二選一),如下操作:
啟動應用程序時,增加--debug或--trace標志
$ java -jar myapp.jar -- debug
說明:使用debug調試模式啟動應用程序不會將應用程序配置為使用DEBUG級別記錄日志。復制代碼
在application.yml中(或application.properties中)增加debug: true或trace: true(或debug=true/trace=true)
application.yml文件:
debug: true
application.properties文件:
debug=true
多彩輸出:
如果終端支持ANSI(表示顏色),可以設置彩色輸出。
application.yml中設置:
# 檢查終端是否支持ANSI,是的話就采用彩色輸出 spring: output: ansi: enabled: detect
application.properties中設置:
# 檢查終端是否支持ANSI,是的話就采用彩色輸出 spring.output.ansi.enabled=detect
文件輸出
SpringBoot默認配置日志只會輸出到控制臺,并不會記錄到文件中,但通常生產環境需要把日志記錄到文件中。
配置屬性如下:
日志文件在達到10 MB時滾動輸出,并且與控制臺輸出一樣,默認情況下會記錄ERROR,WARN和INFO級別的日志??梢允褂胠ogging.file.max-size屬性更改大小限制。除非已設置logging.file.max-history屬性,否則以前輪換的日志文件將被無限期歸檔。(來自官網)
注意點:
日志記錄系統在應用程序生命周期的早期初始化。因此,在通過@PropertySource注解加載的屬性文件中找不到日志記錄屬性。
日志記錄屬性獨立于實際的日志記錄基礎結構。因此,SpringBoot不管理特定的配置密鑰(例如Logback的logback.configurationFile)。 (來自官網)
application.yml中設置:
logging: # 設置相對路徑的日志輸出文件 file: log/my.log # 設置日志輸出路徑,默認會生成log/spring.log日志文件 path: log logging: # 設置絕對路徑的日志輸出文件 file: D:\ideaProjects\SpringBootDemo\log1\mylog1.log # 設置日志輸出路徑,默認會生成log/spring.log日志文件 path: log
application.properties中設置:
logging.file=log/my.log logging.path=log
級別控制
配置屬性格式:logging.level.*=LEVEL
application.yml中設置:
logging: level: # com.example.demo包下所有class以DEBUG級別輸出 com.example.demo: DEBUG # root日志以INFO級別輸出 root: INFO
說明:
配置日志級別值大小寫均可,例如:設置成debug/info
application.properties中設置:
logging.level.com.example.demo=DEBUG logging.level.root=INFO
說明:配置日志級別值大小寫均可,例如:設置成debug/info
刨根問底,死磕自己(選看)
1. 日志級別設置選項
源碼中系統日志級別是個枚舉類,列出了所有日志級別,如下截圖:
根據在application.yml中設置的LEVEL值,匹配系統日志枚舉類,最終設置系統相應包下的日志級別。
SpringBoot官網: https://docs.spring.io/spring-boot/docs/2.1.2.RELEASE/reference/htmlsingle/
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持創新互聯。
本文題目:SpringBoot項目集成日志的實現方法
網頁網址:http://m.2m8n56k.cn/article20/gpoeco.html
成都網站建設公司_創新互聯,為您提供域名注冊、網站收錄、服務器托管、關鍵詞優化、動態網站、小程序開發
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:[email protected]。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯