logback系列之一:輸出日誌到控制檯
slf4j是Java的簡單日誌門面API,不少日誌實現均可以與之集成,如JDK logging (java.util.logging), log4j和logback。優勢是代碼裏不會有具體的日誌實現類,減小侵入。
與log4j相比,logback具備一些優點,如更好的性能、更少的內存使用、自動重加載配置文件以及過濾功能等。
下面簡要介紹下logback的使用:
1. 在pom.xml文件中添加依賴:
Xml代碼
< properties >
< logback.version > 1.0.11</ logback.version >
< slf4j.api.version > 1.7.5</ slf4j.api.version >
</ properties >
< dependencies >
< dependency >
< groupId > org.slf4j</ groupId >
< artifactId > slf4j-api</ artifactId >
< version > ${slf4j.api.version}</ version >
</ dependency >
< dependency >
< groupId > ch.qos.logback</ groupId >
< artifactId > logback-classic</ artifactId >
< version > ${logback.version}</ version >
</ dependency >
< dependency >
< groupId > ch.qos.logback</ groupId >
< artifactId > logback-core</ artifactId >
< version > ${logback.version}</ version >
</ dependency >
</ dependencies >
2. 在類路徑下新建logback.xml或logback-test.xml(優先級高)文件:
Xml代碼
<? xml version ="1.0" encoding ="UTF-8" ?>
< configuration >
< appender name ="STDOUT" class ="ch.qos.logback.core.ConsoleAppender" >
<!-- encoder的默認實現類是ch.qos.logback.classic.encoder.PatternLayoutEncoder -->
< encoder >
< pattern > %d{HH:mm:ss.SSS} [%thread] %-5level %logger{5} - %msg%n</ pattern >
</ encoder >
</ appender >
<!-- name值能夠是包名或具體的類名:該包(包括子包)下的類或該類將採用此logger -->
< logger name ="com.john.logging.b" level ="INFO" >
< appender-ref ref ="STDOUT" />
</ logger >
<!-- root的默認level是DEBUG -->
< root level ="DEBUG" >
< appender-ref ref ="STDOUT" />
</ root >
</ configuration >
3. 測試類:
Java代碼
package com.john.logging.a;
public class Reconciliation {
private static final Logger log = LoggerFactory.getLogger(Reconciliation.class );
public void reconciliate() {
String name = "conciliate" ;
log.info("Hello from reconciliate" );
log.debug("My name is {}" , name);
}
}
Java代碼
package com.john.logging.b;
public class Corruption {
// logger名稱爲類的全限定名
private static final Logger log = LoggerFactory.getLogger(Corruption.class );
public void corrupt() {
String name = "allegation" ;
log.info("Hello from corrupt." );
log.debug("My name is {}" , name);
}
}
輸出:
11:50:16.266 [main] INFO c.j.l.a.Reconciliation - Hello from reconciliate
11:50:16.270 [main] DEBUG c.j.l.a.Reconciliation - My name is conciliate
11:50:16.271 [main] INFO c.j.l.b.Corruption - Hello from corrupt.
11:50:16.271 [main] INFO c.j.l.b.Corruption - Hello from corrupt.
全部logger的始祖是ROOT,默認會繼承ROOT的配置,所以Corruption中的日誌會打印兩次。
解決:logger的additivity屬性設置爲false
Xml代碼
< logger name ="com.john.logging.b" level ="INFO" additivity ="false" >
歡迎關注本站公眾號,獲取更多信息