⑴ Slf4j + Logback 怎麼過濾掉第三方包中的日誌顯示
其實這跟 Slf4J 通用日誌框架沒什麼關系,單單是 Logback 的事,把 Slf4J 扯進來只因它們是對黃金組合。
我們在 log4j 中想要不顯示第三方包的非常冗餘的日誌輸出時,只要在 log4j.properties 中寫上:
1
log4j.logger.org.hibernate=ERROR
這樣在 hibernate 里的日誌級別在 ERROR 以下的 TRACE、DEBUG、WARN 和 INFO 將不被輸出,控制台會比較的干凈。
Logback 的配置文件是 logback.xml,曾經在裡面給 <appender> 加的 <pattern> 是:
1
<pattern>%-4relative [%thread] %-5level %logger{35} - %msg%n</pattern>
logger 名顯示 35 字元,類名優先顯示全,類全限名超過總長度則取前面若干包名的首字母連接起來,於是產生了像下面那樣的日誌輸出:
7937 [main] DEBUG o.s.b.f.s.DefaultListableBeanFactory - Returning cached instance of singleton
7781 [main] DEBUG o.h.loader.entity.EntityLoader - Static select for entity
這在 Log4J 中是未曾見過的。當時還以為日誌名就是 o.s.b.f 這樣的東西,於是在 logback.xml 中用
1
2
<logger name="o.s.b" level="WARN"/>
<logger name="o.h" level="WARN"/>
這樣的代碼來進行封鎖,根本就無濟於事,大量的 spring、hibernate 的 DEBUG、INFO 等日誌照樣輸出。這時惦記起 Logback 的 filter 功能來了,配置上:
01
02
03
04
05
06
07
08
09
10
11
<filter>
<evaluator> <!-- defaults to type ch.qos.logback.classic.boolex.JaninoEventEvaluator -->
<expression><![CDATA[
event.getThreadName().contains("Catalina")
|| event.getLoggerName().contains("o.s.b.f")
|| event.getLoggerName().contains("o.h.")
]]></expression>
</evaluator>
<OnMismatch>NEUTRAL</OnMismatch>
<OnMatch>DENY</OnMatch>
</filter>
也是沒有效果的。想來 Logback 與 Log4J 相比不會這么差勁的,再怎麼也是出自一人之手,想來思路應是一致的,還是該回到 <logger> 的配置上來。
還是 Google 威武,找到答案了:logback per-logger configuration is not working。原來像 "o.s.b.f" 和 "o.h." 這樣的東西只是神馬浮雲,假象而已,它們實際所代表的 logger 名並未變,分別是:
org.springframework.beans.factory.support.DefaultListableBeanFactory
org.hibernate.loader.entity.EntityLoader
所以呢,在 logback.xml 中像 Log4J 一樣寫上
1
2
<logger name="org.hibernate" level="WARN"/>
<logger name="org.springframework" level="WARN"/>
就把 Spring 和 Hibernate 的日誌輸出稍加過濾了,都是 %logger{35} 中的那個 {35} 惹的禍,不過也靠它多了解了一點東西。如果只寫成 %logger 話那時候當然可以很快的解決問題的。
⑵ logback如何設置列印的日誌信息的最大欄位長度
<appender name="ROLLING" class="ch.qos.logback.core.rolling.RollingFileAppender">
<!-- 當發生滾動時 TimeBasedRollingPolicy滾動策略 根據時間來制定滾動策略 -->
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- 按天回滾 daily -->
<!-- local
<fileNamePattern>/Users/liyixiang/Documents/logs/xxx-xxx-${appPort}-%d{-MM-dd}.log</fileNamePattern>
-->
<!-- log.dir 在maven profile里配置 -->
<fileNamePattern>/logs/xxx-xxx-${appPort}-%d{-MM-dd}.log</fileNamePattern>
<!-- 控制保留的歸檔文件的最大數量 日誌最大的歷史 5天 -->
<maxHistory>5</maxHistory>
</rollingPolicy>
<!-- 日誌格式化 -->
<encoder>
<pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - [%msg]%n</pattern>
</encoder>
<p>
</appender>
</p>
<p>
<br>
</p>
<p>
</p><pre class="brush:xml; toolbar: true; auto-links: false;">具體的pattern可以查詢logback pattern like this --> </pre>
<p></p>
⑶ slf4j怎麼屏蔽info和debug級別的日誌
SLF4J是一套簡單的日誌外觀模式的Java API,幫助在項目部署時對接各種日誌實現。
LogBack在運行時使用JMX幫助修改日誌配置,在生產狀態下無需重啟應用程序。
SLF4J
SLF4J是簡單的日誌外觀模式框架,抽象了各種日誌框架例如Logback、Log4j、Commons-logging和JDK自帶的logging實現介面。它使得用戶可以在部署時使用自己想要的日誌框架。SLF4J是輕量級的,在性能方面幾乎是零消耗的。
SLF4J沒有替代任何日誌框架,它僅僅是標准日誌框架的外觀模式。如果在類路徑下除了SLF4J再沒有任何日誌框架,那麼默認狀態是在控制台輸出日誌。
Logback
Logback是Log4j的改進版本,而且原生支持SLF4J(因為是同一作者開發的),因此從其它日誌框架如Log4j或JDK的logging遷移到Logback是完全可行的。
由於Logback原生支持SLF4J,因此Logback+SLF4J的組合是日誌框架的最佳選擇,比SLF4J+其它日誌框架的組合要快一些。而且Logback的配置可以是XML或Groovy代碼。
注意一個重要的特性,Logback通過JMX修改日誌配置(比如日誌級別從Debug調整到INFO),可以從JMX控制台直接操作,無需重啟應用程序。
此外,Logback的異常堆棧跟蹤的信息,有助於調試。
[java] view plain print?
java.lang.NullPointerException: null
at com.fimt.poc.LoggingSample.<init>(LoggingSample.java:16) [classes/:na]
at com.fimt.poc.LoggingSample.main(LoggingSample.java:23) [fimt-logging-poc-1.0.jar/:1.0]
SLF4J API用法
1. 從org.slf4j包導入Logger和LoggerFactory
[java] view plain print?
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
2. 聲明日誌類
[java] view plain print?
private final Logger logger = LoggerFactory.getLogger(LoggingSample.class);
3. 使用debug、warn、info、error方法並跟蹤適合的參數。
所有的方法默認都使用字元串作為輸入。
[java] view plain print?
logger.info("This is sample info statement");
SLF4J結合Logback
在pom.xml包含下面的依賴:它會自動包含所有的依賴包logback-core、slf4j-api……
[html] view plain print?
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
<version>1.0.7</version>
</dependency>
SLF4J能用於現有的日誌框架如Log4j、Commons-logging、java.util.logging(JUL)。
SLF4J結合Log4j
在pom.xml包含下面的依賴
[html] view plain print?
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>1.7.2</version>
</dependency>
SLF4J結合JUL (java.util.logging)
在pom.xml包含下面的依賴
[html] view plain print?
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-jdk14</artifactId>
<version>1.7.2</version>
</dependency>
⑷ logback的日誌在java的textarea顯示中文亂碼
logback的日誌在java的textarea顯示中文亂碼可能是出現了程序上的問題,需要檢查一遍
⑸ logback.xml怎麼設置字元集
http://zan77552011.blog.51cto.com/5106659/1664290
解決不了,再追問
⑹ 為什麼要用SLF4J+Logback 替換commons-logging+log4j
SLF4J是編譯時綁定到具體的日誌框架,性能優於採用運行時搜尋的方式的commons-logging。
SLF4J提供了更好的日誌記錄方式,帶來下這幾方面的好處:
1、更好的可讀性;
2、不需要使用logger.isDebugEnabled()來解決日誌因為字元拼接產生的性能問題。
先參考2,logback支持了更方便的自定義日誌,便於後期的日誌分析,
可以將日誌格式化保存到各種存儲引擎中,
這里是推崇用 Logback 替代 Log4J 的十幾個理由,
大至是更快;
好測試;
與 SLF4J 關系緊;
文檔豐富;
能自動載入配置文件;
多個 JVM 寫一個日誌文件,或其他 I/O 錯誤時不影響程序執行;
配置文件中加入條件控制;
強大的日誌過濾;
更強的日誌切分功能;
自動壓縮、刪除日誌文件;
異常棧中更多的數據信息。
⑺ IDEA下使用logback控制台列印日誌中文字元為亂碼怎麼破
打開File Encodings,方法:
windows:進入設置頁。File-->Settings (快捷鍵:Ctrl+Alt+S),快速搜索輸入encoding
mac:Intellij IDEA-->Preferences,快速搜索輸入encoding
如下圖所示。
2. 紅框內,IDE Encoding 選擇UTF-8,Project Encoding選擇 GB2312(這個選項跟源碼中的字元編碼相關)
3. 在靠下的紅框內,對於源碼,在Default Encoding一欄選擇GB2312,並保證該源碼目錄下的所有文件沒有選擇其他編碼方式(即都使用默認的GB2312)
4.點擊OK結束。
⑻ Slf4j + Logback 怎麼過濾掉第三方包中的日誌顯示
1.自動清除法抄開放數據襲庫選項 Trunc Log on Chkpt,使資料庫系統每隔一段時間自動清除Log。此方法的優點是無須人工干預,由SQLServer自動執行,並且一般不會出現Log溢滿的情況;缺點是只清除Log而不做備份。2.手動清除法執行命令「mp transaction」來清除Log。以下兩條命令都可以清除日誌:mp transaction with truncate_only mp transaction with no_log
⑼ Slf4j + Logback 怎麼過濾掉第三方包中的日誌顯示
SLF4J是一套簡單的日誌外觀模式的Java API,幫助在項目部署時對接各種日誌實現。專 LogBack在運行時使用JMX幫助修改日誌配屬置,在生產狀態下無需重啟應用程序。 SLF4J SLF4J是簡單的日誌外觀模式框架,抽象了各種日誌框架例如Logback、Log4j、Commo...
⑽ logback.xml 怎麼設置info信息顯示控制台,而debug信息寫日誌
<filter class="ch.qos.logback.classic.filter.ThresholdFilter">
<level>INFO</level>
</filter>
ThresholdFilter is shown below. 級別過濾,臨界回點判斷答