slf4j使用log4j的配置參數(shù)方式
slf4j使用log4j的配置參數(shù)
slf4j,即簡單日志門面(Simple Logging Facade for Java),不是具體的日志解決方案,它只服務(wù)于各種各樣的日志系統(tǒng)。
按照官方的說法,SLF4J是一個用于日志系統(tǒng)的簡單Facade,允許最終用戶在部署其應(yīng)用時使用其所希望的日志系統(tǒng)。
比如用戶可以自己選擇使用 log4j 或是 log4j2 。
slf4j 的 maven 配置如下
<dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-api</artifactId> <version>1.7.21</version> </dependency> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-log4j12</artifactId> <version>1.7.21</version> </dependency>
關(guān)于具體的配置 log4j.properties
### 設(shè)置rootLogger ### log4j.rootLogger = info,stdout,D,E ### 輸出信息到控制臺 ### ### 控制臺輸出 log4j.appender.stdout = org.apache.log4j.ConsoleAppender ### 默認是system.out,如果system.err是紅色提示 log4j.appender.stdout.Target = System.out ### 布局格式,可以靈活指定 log4j.appender.stdout.layout = org.apache.log4j.PatternLayout ### 消息格式化 log4j.appender.stdout.layout.ConversionPattern = [%-5p] %d{yyyy-MM-dd HH:mm:ss,SSS} method:%l%n%m%n ### 輸出INFO 級別以上的日志到=D://logs/error.log ### ### 以每天一個文件輸出日志 log4j.appender.D = org.apache.log4j.DailyRollingFileAppender ### 輸出文件目錄 log4j.appender.D.File = D://logs/log.log ### 消息增加到指定的文件中,false表示覆蓋指定文件內(nèi)容 log4j.appender.D.Append = true ### 輸出信息最低級別 log4j.appender.D.Threshold = INFO log4j.appender.D.layout = org.apache.log4j.PatternLayout log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n ### 輸出ERROR 級別以上的日志到=D://logs/error.log ### log4j.appender.E = org.apache.log4j.DailyRollingFileAppender log4j.appender.E.File =D://logs/error.log log4j.appender.E.Append = true log4j.appender.E.Threshold = ERROR log4j.appender.E.layout = org.apache.log4j.PatternLayout log4j.appender.E.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n
日志級別
主要有以下:
ERROR
錯誤WARN
警告INFO
一般信息DEBUG
調(diào)試信息
常用的輸出位置
ConsoleAppender
控制臺FileAppender
文件DailyRollingFileAppender
每天產(chǎn)生一個日志文件RollingFileAppender
文件大小達到指定尺寸時產(chǎn)生一個新文件WriterAppeder
將日志信息以流格式發(fā)送到指定地方
格式化輸出
-X號
: X信息輸出時左對齊;%p
: 輸出日志信息優(yōu)先級,即DEBUG,INFO,WARN,ERROR,F(xiàn)ATAL,%d
: 輸出日志時間點的日期或時間,默認格式為ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss,SSS},輸出類似:2002年10月18日 22:10:28,921%r
: 輸出自應(yīng)用啟動到輸出該log信息耗費的毫秒數(shù)%c
: 輸出日志信息所屬的類目,通常就是所在類的全名%t
: 輸出產(chǎn)生該日志事件的線程名%l
: 輸出日志事件的發(fā)生位置,相當于%C.%M(%F:%L)的組合,包括類目名、發(fā)生的線程,以及在代碼中的行數(shù)。舉例:Testlog4.main (TestLog4.java:10)%x
: 輸出和當前線程相關(guān)聯(lián)的NDC(嵌套診斷環(huán)境),尤其用到像Java servlets這樣的多客戶多線程的應(yīng)用中。%%
: 輸出一個”%”字符%F
: 輸出日志消息產(chǎn)生時所在的文件名稱%L
: 輸出代碼中的行號%m
: 輸出代碼中指定的消息,產(chǎn)生的日志具體信息
有時我們看到 %-5p 或者 %5p 意思就是輸出日志級別時,左對齊或右對齊,4個字母的 INFO / WARN 要補一個空格,才能和 DEBUG / ERROR 對齊格式。
slf4j集成log4j小結(jié)
日志配置使用 Slf4j集成 log4j
- 為什么使用slf4j
- slf4j集成log4j所需jar包及maven配置
- slf4j及l(fā)og4j配置文件
- slf4j集成log4j示例
為什么使用slf4j
SLF4J,即簡單日志門面(Simple Logging Facade for Java),不是具體的日志解決方案,它只服務(wù)于各種各樣的日志系統(tǒng)。按照官方的說法,SLF4J是一個用于日志系統(tǒng)的簡單Facade,允許最終用戶在部署其應(yīng)用時使用其所希望的日志系統(tǒng)。通過示例說明該特性:
public class App { final Logger logger = LoggerFactory.getLogger(App.class); private void test() { logger.info("這是一條日志信息 - {}", "mafly"); } public static void main(String[] args) { App app = new App(); app.test(); System.out.println("Hello World!"); } }
對于不同的日志系統(tǒng)而言只需增加slf4j依賴包
<groupId>org.slf4j</groupId> <artifactId>slf4j-api</artifactId> <version>1.7.22</version> </dependency>
對于使用logback日志系統(tǒng)用戶而言 配置
<dependency> <groupId>ch.qos.logback</groupId> <artifactId>logback-core</artifactId> <version>1.1.9</version> </dependency> <dependency> <groupId>ch.qos.logback</groupId> <artifactId>logback-classic</artifactId> <version>1.1.9</version> </dependency>
同時配置logback.xml的配置文件,即可使用slf4j管理日志系統(tǒng),同時如果想要切換日志系統(tǒng),例如 想要切換到log4j,無需修改代碼,只需將上述logback dependency刪除,增加log4j的配置
<dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-log4j12</artifactId> <version>1.7.21</version> </dependency> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>1.2.17</version> </dependency>
可以實現(xiàn)不修改代碼,更改日志系統(tǒng)的功能。
slf4j集成log4j所需jar包及maven配置
<dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-api</artifactId> <version>1.7.21</version> </dependency> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-log4j12</artifactId> <version>1.7.21</version> </dependency> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>1.2.17</version> </dependency>
所需外部支持可分為三部分:slf4j-api包 log4j包 以及slf4j-log4j12guanlainbao
slf4j及l(fā)og4j配置文件
在 src/main/resources中 new–>resource bundle —->寫入文件名 log4j 生成log4j.properties文件
### config root logger log4j.rootLogger=info, STDOUT
配置根logger 格式為 [level],appenderName1,appenderName2……
其中[level]共分為5級,如下:
- FATAL 0
- ERROR 3
- WARN 4
- INFO 6
- DEBUG 7
appendername是配置日志輸出的目的地
log4j.appender.STDOUT=org.apache.log4j.ConsoleAppender log4j.appender.STDOUT.Target=System.out log4j.appender.STDOUT.layout=org.apache.log4j.PatternLayout log4j.appender.STDOUT.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} %5p %c{1}:%L - %m%n
其中appender的類型有如下幾種:
org.apache.log4j.ConsoleAppender(控制臺), org.apache.log4j.FileAppender(文件), org.apache.log4j.DailyRollingFileAppender(每天產(chǎn)生一個日志文件), org.apache.log4j.RollingFileAppender(文件大小到達指定尺寸的時候產(chǎn)生一個新的文件), org.apache.log4j.WriterAppender(將日志信息以流格式發(fā)送到任意指定的地方)
輸出格式layout有如下幾種
org.apache.log4j.HTMLLayout(以HTML表格形式布局), org.apache.log4j.PatternLayout(可以靈活地指定布局模式), org.apache.log4j.SimpleLayout(包含日志信息的級別和信息字符串), org.apache.log4j.TTCCLayout(包含日志產(chǎn)生的時間、線程、類別等等信息)
打印參數(shù)配置如下:
%m
輸出代碼中指定的消息%p
輸出優(yōu)先級,即DEBUG,INFO,WARN,ERROR,F(xiàn)ATAL%r
輸出自應(yīng)用啟動到輸出該log信息耗費的毫秒數(shù)%c
輸出所屬的類目,通常就是所在類的全名%t
輸出產(chǎn)生該日志事件的線程名%n
輸出一個回車換行符,Windows平臺為“\r\n”,Unix平臺為“\n”%d
輸出日志時間點的日期或時間,默認格式為ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss , SSS},輸出類似:2002年10月18日 22 : 10 : 28 , 921%l
輸出日志事件的發(fā)生位置,包括類目名、發(fā)生的線程,以及在代碼中的行數(shù)。舉例:Testlog4.main(TestLog4.java: 10 )
輸出到文件中示例:
### 輸出到日志文件 ### log4j.appender.D = org.apache.log4j.DailyRollingFileAppender log4j.appender.D.File = logs/log.log log4j.appender.D.Append = true log4j.appender.D.Threshold = DEBUG ## 輸出DEBUG級別以上的日志 log4j.appender.D.layout = org.apache.log4j.PatternLayout log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n
slf4j集成log4j
約定大于配置,如果將log4j.properties放置在classpath中,即resources文件夾下 可自動讀取
private static final Logger logger= LoggerFactory.getLogger(TestUtil.class); public static void main(String [] args){ logger.info("info信息"); logger.debug("debug信息"); }
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
使用java springboot設(shè)計實現(xiàn)的圖書管理系統(tǒng)(建議收藏)
這篇文章主要介紹了使用java springboot設(shè)計實現(xiàn)的圖書管理系統(tǒng),包含了整個的開發(fā)過程,以及過程中遇到的問題和解決方法,對大家的學習和工作具有借鑒意義,建議收藏一下2021-08-08Java設(shè)計模式模板方法模式(Template)用法解析
這篇文章主要介紹了Java設(shè)計模式模板方法模式(Template)用法解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-11-11String?concat(String?str)使用小結(jié)
這篇文章主要介紹了String?concat(String?str)使用小結(jié),在了解concat()之前,首先需要明確的是String的兩點特殊性,一是長度不可變二是值不可變,本文給大家詳細講解,需要的朋友可以參考下2022-11-11mybatis中方法返回泛型與resultType不一致的解決
這篇文章主要介紹了mybatis中方法返回泛型與resultType不一致的解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-07-07淺談java中集合的由來,以及集合和數(shù)組的區(qū)別詳解
下面小編就為大家?guī)硪黄獪\談java中集合的由來,以及集合和數(shù)組的區(qū)別詳解。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-10-10JavaWeb Struts文件上傳功能實現(xiàn)詳解
這篇文章主要為大家詳細介紹了JavaWeb Struts文件上傳功能實現(xiàn)過程,思路清晰,供大家參考,感興趣的小伙伴們可以參考一下2016-06-06