柚子快報(bào)邀請(qǐng)碼778899分享:log4j
柚子快報(bào)邀請(qǐng)碼778899分享:log4j
Log4j有三個(gè)主要的組件/對(duì)象:Loggers(記錄器),Appenders (輸出源)和Layouts(布局)。這里可簡單理解為日志類別,日志要輸出的地方和日志以何種形式輸出。 每條日志語句都要設(shè)置一個(gè)等級(jí)(DEBUG、INFO、WARN、ERROR和FATAL)。其中DEBUG ? Loggers 在設(shè)置日志輸出位置的時(shí)候,會(huì)給那個(gè)位置設(shè)置一個(gè)級(jí)別,只有大于等于那個(gè)級(jí)別的日志才會(huì)打印輸出到指定位置,例如:某個(gè)Loggers(日志輸出位置的等級(jí)記錄器)級(jí)別設(shè)定為INFO,則INFO、WARN、ERROR和FATAL級(jí)別的日志信息都會(huì)輸出到那個(gè)文件,而級(jí)別比INFO低的DEBUG則不會(huì)輸出。 Appenders 禁用和使用日志請(qǐng)求只是Log4i的基本功能,Log4i日志系統(tǒng)還提供許多強(qiáng)大的功能,比如允許把日志輸出到不同的地方,如控制臺(tái)(Console)、文件(Files)等,可以根據(jù)天數(shù)或者文件大小產(chǎn)生新的文件,可以以流的形式發(fā)送到其它地方等等, 常使用的類如下: org.apache.log4j.ConsoleAppender(控制臺(tái)) org.apache.log4j.FileAppender(文件) org.apache.log4j.DailyRollingFileAppender(每天產(chǎn)生一個(gè)日志文件) org.apache.og4j.RollingFileApender(文件大小到達(dá)指定尺寸的時(shí)候產(chǎn)生一個(gè)新的文件) org.apache.log4j.WriterAppender(將日志信息以流格式發(fā)送到任意指定的地方) 基本上可以滿足我們的日常需求,當(dāng)然如果你的需求比較特殊,可以自己實(shí)現(xiàn)Appender輸出路徑。只需要定義一個(gè)類,實(shí)現(xiàn)Appender接口就可以了。Appender接口中定義了一系列記錄日志的方法,按照自己的規(guī)則實(shí)現(xiàn)這些方法即可 Layouts 用戶可以根據(jù)自己的喜好格式化自己的日志輸出,Layouts提供四種日志輸出樣式,如根據(jù)HTML樣式、自由指定樣式、包含日志級(jí)別與信息的樣式和包含日志時(shí)間、線程、類別等信息的樣式。 常使用的類如下: org.apache.log4j.HTMLLayout(以HTML表格形式布局) org.apache.log4j.PatternLayout(可以靈活地指定布局模式) org.apache.log4j.SimpleLayout(包含日志信息的級(jí)別和信息字符串) org.apache.log4j.TTCCLayout(包含日志產(chǎn)生的時(shí)間、線程、類別等信息) 配置日志信息的布局,其語法為: log4j.appender.appenderName.layout = fully.qualified.name.of.layout.class log4j.appender.appenderName.layout.optionl =value1 log4j.appender.appenderName.layout.option =valueN 其中,Log4j提供的1ayout有以下幾種: org.apache.1og4j.HTMLLayout(以HTML表格形式布局) org.apache.1og4j.PatternLayout(可以靈活地指定布局模式), org.apache.1og4j.simpleLayout(包含日志信息的級(jí)別和信息字符串) org.apache.1og4j.TTCCLayout(包含日志產(chǎn)生的時(shí)間、線程、類別等等信息) log4j.properties log4j.rootLogger=DEBUG, stdout log4j.logger.com.example=INFO log4j.logger.com.example.subpackage=DEBUG ###設(shè)置在控制臺(tái)輸出### log4j.appender.stdout=org.apache.log4j.ConsoleAppender log4j.appender.stdout.Target=System.out ###設(shè)置輸出的特定格式### log4j.appender.stdout.layout=org.apache.log4j.PatternLayout log4j.appender.stdout.layout.ConversionPattern=%d [%t] %p %c - %m%n ###輸出ERROR級(jí)別以上的日志到D://logs/myapp.log### log4j.appender.file=org.apache.log4j.FileAppender log4j.appender.file.File=D://logs/myapp.log log4j.appender.file.Append=true log4j.appender.file.Threshold=ERROR log4j.appender.file.layout=org.apache.log4j.PatternLayout log4j.appender.file.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n dependcy 柚子快報(bào)邀請(qǐng)碼778899分享:log4j 文章鏈接
本文內(nèi)容根據(jù)網(wǎng)絡(luò)資料整理,出于傳遞更多信息之目的,不代表金鑰匙跨境贊同其觀點(diǎn)和立場(chǎng)。
轉(zhuǎn)載請(qǐng)注明,如有侵權(quán),聯(lián)系刪除。