導航:首頁 > 凈水問答 > logback過濾特定日誌

logback過濾特定日誌

發布時間:2022-01-26 06:29:42

A. java怎麼用logback做日誌記錄以html的形式展示

<span style="font-size:12px;">import java.text.SimpleDateFormat;
import java.util.Date;

import org.slf4j.LoggerFactory;

import ch.qos.logback.classic.Logger;
import ch.qos.logback.classic.LoggerContext;
import ch.qos.logback.classic.encoder.PatternLayoutEncoder;
import ch.qos.logback.classic.spi.ILoggingEvent;
import ch.qos.logback.core.FileAppender;

/**
* 根據不同的日誌類型,列印不同路徑下的yyyyMMdd.log格式日誌,例如./logs/flume/playerLogin/20141111.log
* @author [email protected]
*/
public class LoggerUtil {

public static Logger getLogger(Class<?> clazz) {

Logger rootLogger = (Logger) LoggerFactory.getLogger(clazz);
LoggerContext loggerContext = rootLogger.getLoggerContext();
//loggerContext.reset();

PatternLayoutEncoder encoder = new PatternLayoutEncoder();
encoder.setContext(loggerContext);
encoder.setPattern("%m");
encoder.start();

FileAppender<ILoggingEvent> appender = new FileAppender<ILoggingEvent>();
String fileName = getTime("yyyyMMdd") + ".log";
String filePath = LogPathConst.LOG_PREFIX + clazz.getSimpleName() + "/" + fileName;
appender.setFile(filePath);
appender.setContext(loggerContext);
appender.setEncoder(encoder);
appender.start();
rootLogger.addAppender(appender);

return rootLogger;

}

private static String getTime(String format) {
SimpleDateFormat sdf = new SimpleDateFormat(format);
return sdf.format(new Date());
}
}
</span>

B. Slf4j + Logback 怎麼過濾掉第三方包中的日誌顯示

你好,
可設置緩存後批量寫日誌文件(但伺服器如果重啟,可能會丟失未寫到磁碟的記錄)使用log4j作者的新作logback+slf4j,因為可以參數化的語句

C. logback :項目中運行時 控制台沒有logback日誌產生

INFO ThresholdFilter is shown below. 級別過濾,臨界點判斷

D. logback.xml 怎麼設置info信息顯示控制台,而debug信息寫日誌

<filter class="ch.qos.logback.classic.filter.ThresholdFilter">
<level>INFO</level>
</filter>
ThresholdFilter is shown below. 級別過濾,臨界回點判斷答

E. java啟動如何去掉logback自身調試信息

debug屬性設置用處不大

最簡配置:


<?xmlversion="1.0"encoding="UTF-8"?>

<configurationscan="true"scanPeriod="60seconds">

<appendername="stdout"class="ch.qos.logback.core.ConsoleAppender">

<filterclass="ch.qos.logback.classic.filter.ThresholdFilter">

<level>INFO</level>

</filter>

<encoder>

<pattern>%d{yyyy-MM-ddHH:mm:ss.SSS}[%thread]%-5level%logger{50}-%msg%n</pattern>

</encoder>

</appender>

<rootlevel="INFO">

<appender-refref="stdout"/>

</root>

</configuration>


關鍵是filter。沒有這,那什麼設置都不行


後來,原因未知。又不行了!!日!


參照網頁鏈接

添加<statusListener class="ch.qos.logback.core.status.NopStatusListener" />

解決

將狀態信息監聽器設置為無操作監聽器。



其實這些都不重要,最主要的是把提示的報錯問題解決掉!


舉個例子,把舊的layout標簽,換為encoder。

你試試就知道了!

F. 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{yyyy-MM-dd}.log</fileNamePattern>
-->
<!-- log.dir 在maven profile里配置 -->
<fileNamePattern>/logs/xxx-xxx-${appPort}-%d{yyyy-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 --> http://aub.iteye.com/blog/1103685</pre>
<p></p>

G. 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

H. 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 話那時候當然可以很快的解決問題的。

I. logback怎麼根據logger輸出不同文件

為了方便查看和歸檔:
不同包的日誌可能要放到不同的文件中,如service層和層的日誌;
不同日誌級別:調試、信息、警告和錯誤等也要分文件輸出。

一、根據包輸出,通過logger的name屬性指定不同的包

1. 創建不同包下的兩個類:

Java代碼
package com.john.service;

@Service
public class ObligationService {
static final Logger log = LoggerFactory.getLogger(ObligationService.class);

@Resource
ObligationDao ;

public void obligate() {
log.debug("obligate start...");
.queryObligations();
log.error("An error occurred ring the progress");
log.debug("obligate end...");
}
}

Java代碼
package com.john.;

@Repository
public class ObligationDao {
static final Logger log = LoggerFactory.getLogger(ObligationDao.class);

public void queryObligations() {
log.debug("query obligations start...");
log.error("An error occurred ring the query");
log.debug("query obligations end...");
}
}

2. 在logback(-test).xml中添加:

Xml代碼
<appender name="serviceAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>/logs/bribery.log</file>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>/logs/bribery-%d{yyyy-MM-dd}.log</fileNamePattern>
</rollingPolicy>
<encoder>
<pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{5} - %msg%n</pattern>
</encoder>
</appender>

<appender name="Appender" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>/logs/venality.log</file>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>/logs/venality-%d{yyyy-MM-dd}.log</fileNamePattern>
</rollingPolicy>
<encoder>
<pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{5} - %msg%n</pattern>
</encoder>
</appender>

<logger name="com.john.service" level="DEBUG" additivity="false">
<appender-ref ref="serviceAppender" />
</logger>

<logger name="com.john." level="DEBUG" additivity="false">
<appender-ref ref="Appender" />
</logger>

在類路徑下創建Spring的beans.xml文件:(beans節點省略)

Xml代碼
<context:component-scan base-package="com.john" />

3. 測試方法:

Java代碼
@Test
public void dispatchByPackageTest() {
AbstractApplicationContext ctx = new ("beans.xml");
ObligationService service = ctx.getBean(ObligationService.class);
service.obligate();
}

執行測試後,
bribery.log:
15:59:59.839 [main] DEBUG c.j.s.ObligationService - obligate start...
15:59:59.844 [main] ERROR c.j.s.ObligationService - An error occurred ring the progress
15:59:59.844 [main] DEBUG c.j.s.ObligationService - obligate end...

venality.log:
15:59:59.844 [main] DEBUG c.j.d.ObligationDao - query obligations start...
15:59:59.844 [main] ERROR c.j.d.ObligationDao - An error occurred ring the query
15:59:59.844 [main] DEBUG c.j.d.ObligationDao - query obligations end...

二、根據日誌級別輸出

這里把所有級別為ERROR的日誌輸出到一個文件中

1. 修改logback(-test).xml文件

serviceAppender和Appender都加入以下級別過濾器,這樣錯誤日誌就不會在bribery.log和venality.log中列印了:

Xml代碼
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<level>ERROR</level>
<onMatch>DENY</onMatch>
<onMismatch>ACCEPT</onMismatch>
</filter>

新建一個錯誤日誌的appender:

Xml代碼
<appender name="errorAppender" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>/logs/error.log</file>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>/logs/venality-%d{yyyy-MM-dd}.log</fileNamePattern>
</rollingPolicy>
<encoder>
<pattern>%d{HH:mm:ss.SSS} %thread %X{invokeNo} %logger{40} %msg%n</pattern>
</encoder>
<filter class="ch.qos.logback.classic.filter.LevelFilter"><!-- 只列印錯誤日誌 -->
<level>ERROR</level>
<onMatch>ACCEPT</onMatch>
<onMismatch>DENY</onMismatch>
</filter>
</appender>

name為com.john.和com.john.service的logger都加上errorAppender:

Xml代碼
<appender-ref ref="errorAppender" />

2. 執行上面的測試方法,service和的錯誤日誌都列印到error.log文件中了:
16:12:51,433 main com.john..ObligationDao An error occurred ring the query
16:12:51,433 main com.john.service.ObligationService An error occurred ring the progress

J. Slf4j + Logback 怎麼過濾掉第三方包中的日誌顯示

SLF4J是一套簡單的日誌外觀模式的Java API,幫助在項目部署時對接各種日誌實現。 LogBack在運行時使用JMX幫助修改日誌配置,在生產狀態下無需重啟應用程序。 SLF4J SLF4J是簡單的日誌外觀模式框架,抽象了各種日誌框架例如Logback、Log4j、Commo...

閱讀全文

與logback過濾特定日誌相關的資料

熱點內容
瓷磚除垢劑不銹鋼變黑補救 瀏覽:180
過濾棉出售 瀏覽:808
臨沂生產雨污水管廠家 瀏覽:336
野馬漢騰空調濾芯在哪裡 瀏覽:504
神仙水用蒸餾水稀釋 瀏覽:753
離子交換器設計規范 瀏覽:523
晉州如何處理工業廢水 瀏覽:39
凈水機能賣什麼廢品 瀏覽:822
光澤環氧樹脂地坪 瀏覽:506
小區裝修垃圾水處理 瀏覽:512
養殖廢水濃度一般是多少 瀏覽:962
躍進濾芯怎麼樣 瀏覽:258
億能電池能加蒸餾水 瀏覽:838
六月份北京回牡丹江用隔離嗎 瀏覽:796
空氣凈化器沒有加濕功能怎麼辦 瀏覽:583
內膽式樹脂混凝土 瀏覽:28
為什麼反滲透膜要通電 瀏覽:821
反滲透膜價格j上海保茲 瀏覽:572
pp棉濾芯如何切 瀏覽:665
汽車油箱口過濾網密度怎麼樣 瀏覽:198