|
logback 常用配置詳解(三) <filter> <filter>: 過(guò)濾器,執(zhí)行一個(gè)過(guò)濾器會(huì)有返回個(gè)枚舉值,即DENY,NEUTRAL,ACCEPT其中之一。返回DENY,日志將立即被拋棄不再經(jīng)過(guò)其他過(guò)濾器;返回NEUTRAL,有序列表里的下個(gè)過(guò)濾器過(guò)接著處理日志;返回ACCEPT,日志會(huì)被立即處理,不再經(jīng)過(guò)剩余過(guò)濾器。 過(guò)濾器被添加到<Appender> 中,為<Appender> 添加一個(gè)或多個(gè)過(guò)濾器后,可以用任意條件對(duì)日志進(jìn)行過(guò)濾。<Appender> 有多個(gè)過(guò)濾器時(shí),按照配置順序執(zhí)行。 下面是幾個(gè)常用的過(guò)濾器: LevelFilter: 級(jí)別過(guò)濾器,根據(jù)日志級(jí)別進(jìn)行過(guò)濾。如果日志級(jí)別等于配置級(jí)別,過(guò)濾器會(huì)根據(jù)onMath 和 onMismatch接收或拒絕日志。有以下子節(jié)點(diǎn): <level>:設(shè)置過(guò)濾級(jí)別 <onMatch>:用于配置符合過(guò)濾條件的操作 <onMismatch>:用于配置不符合過(guò)濾條件的操作 例如:將過(guò)濾器的日志級(jí)別配置為INFO,所有INFO級(jí)別的日志交給appender處理,非INFO級(jí)別的日志,被過(guò)濾掉。 - <configuration>
- <appender name="CONSOLE" class="ch.qos.logback.core.ConsoleAppender">
- <filter class="ch.qos.logback.classic.filter.LevelFilter">
- <level>INFO</level>
- <onMatch>ACCEPT</onMatch>
- <onMismatch>DENY</onMismatch>
- </filter>
- <encoder>
- <pattern>
- %-4relative [%thread] %-5level %logger{30} - %msg%n
- </pattern>
- </encoder>
- </appender>
- <root level="DEBUG">
- <appender-ref ref="CONSOLE" />
- </root>
- </configuration>
ThresholdFilter: 臨界值過(guò)濾器,過(guò)濾掉低于指定臨界值的日志。當(dāng)日志級(jí)別等于或高于臨界值時(shí),過(guò)濾器返回NEUTRAL;當(dāng)日志級(jí)別低于臨界值時(shí),日志會(huì)被拒絕。 例如:過(guò)濾掉所有低于INFO級(jí)別的日志。 - <configuration>
- <appender name="CONSOLE"
- class="ch.qos.logback.core.ConsoleAppender">
-
- <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
- <level>INFO</level>
- </filter>
- <encoder>
- <pattern>
- %-4relative [%thread] %-5level %logger{30} - %msg%n
- </pattern>
- </encoder>
- </appender>
- <root level="DEBUG">
- <appender-ref ref="CONSOLE" />
- </root>
- </configuration>
EvaluatorFilter: 求值過(guò)濾器,評(píng)估、鑒別日志是否符合指定條件。有一下子節(jié)點(diǎn): <evaluator>: 鑒別器,常用的鑒別器是JaninoEventEvaluato,也是默認(rèn)的鑒別器,它以任意的java布爾值表達(dá)式作為求值條件,求值條件在配置文件解釋過(guò)成功被動(dòng)態(tài)編譯,布爾值表達(dá)式返回true就表示符合過(guò)濾條件。evaluator有個(gè)子標(biāo)簽<expression>,用于配置求值條件。 求值表達(dá)式作用于當(dāng)前日志,logback向求值表達(dá)式暴露日志的各種字段: | Name | Type | Description |
|---|
| event | LoggingEvent | 與記錄請(qǐng)求相關(guān)聯(lián)的原始記錄事件,下面所有變量都來(lái)自event,例如,event.getMessage()返回下面"message"相同的字符串 | | message | String | 日志的原始消息,例如,設(shè)有l(wèi)ogger mylogger,"name"的值是"AUB",對(duì)于 mylogger.info("Hello {}",name); "Hello {}"就是原始消息。 | | formatedMessage | String | 日志被各式話的消息,例如,設(shè)有l(wèi)ogger mylogger,"name"的值是"AUB",對(duì)于 mylogger.info("Hello {}",name); "Hello Aub"就是格式化后的消息。 | | logger | String | logger 名。
| | loggerContext | LoggerContextVO | 日志所屬的logger上下文。 | | level | int | 級(jí)別對(duì)應(yīng)的整數(shù)值,所以 level > INFO 是正確的表達(dá)式。 | | timeStamp | long | 創(chuàng)建日志的時(shí)間戳。 | | marker | Marker | 與日志請(qǐng)求相關(guān)聯(lián)的Marker對(duì)象,注意“Marker”有可能為null,所以你要確保它不能是null。 | | mdc | Map | 包含創(chuàng)建日志期間的MDC所有值得map。訪問(wèn)方法是:mdc.get("myKey") 。mdc.get()返回的是Object不是String,要想調(diào)用String的方法就要強(qiáng)轉(zhuǎn),例如, ((String) mdc.get("k")).contains("val") .MDC可能為null,調(diào)用時(shí)注意。
| | throwable | java.lang.Throwable | 如果沒有異常與日志關(guān)聯(lián)"throwable" 變量為 null. 不幸的是, "throwable" 不能被序列化。在遠(yuǎn)程系統(tǒng)上永遠(yuǎn)為null,對(duì)于與位置無(wú)關(guān)的表達(dá)式請(qǐng)使用下面的變量throwableProxy | | throwableProxy | IThrowableProxy | 與日志事件關(guān)聯(lián)的異常代理。如果沒有異常與日志事件關(guān)聯(lián),則變量"throwableProxy" 為 null. 當(dāng)異常被關(guān)聯(lián)到日志事件時(shí),"throwableProxy" 在遠(yuǎn)程系統(tǒng)上不會(huì)為null |
<onMatch>:用于配置符合過(guò)濾條件的操作 <onMismatch>:用于配置不符合過(guò)濾條件的操作 例如:過(guò)濾掉所有日志消息中不包含“billing”字符串的日志。 - <configuration>
-
- <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
- <filter class="ch.qos.logback.core.filter.EvaluatorFilter">
- <evaluator>
- <expression>return message.contains("billing");</expression>
- </evaluator>
- <OnMatch>ACCEPT </OnMatch>
- <OnMismatch>DENY</OnMismatch>
- </filter>
- <encoder>
- <pattern>
- %-4relative [%thread] %-5level %logger - %msg%n
- </pattern>
- </encoder>
- </appender>
-
- <root level="INFO">
- <appender-ref ref="STDOUT" />
- </root>
- </configuration>
<matcher> : 匹配器,盡管可以使用String類的matches()方法進(jìn)行模式匹配,但會(huì)導(dǎo)致每次調(diào)用過(guò)濾器時(shí)都會(huì)創(chuàng)建一個(gè)新的Pattern對(duì)象,為了消除這種開銷,可以預(yù)定義一個(gè)或多個(gè)matcher對(duì)象,定以后就可以在求值表達(dá)式中重復(fù)引用。<matcher>是<evaluator>的子標(biāo)簽。 <matcher>中包含兩個(gè)子標(biāo)簽,一個(gè)是<name>,用于定義matcher的名字,求值表達(dá)式中使用這個(gè)名字來(lái)引用matcher;另一個(gè)是<regex>,用于配置匹配條件。 例如: - <configuration debug="true">
-
- <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
- <filter class="ch.qos.logback.core.filter.EvaluatorFilter">
- <evaluator>
- <matcher>
- <Name>odd</Name>
-
- <regex>statement [13579]</regex>
- </matcher>
-
- <expression>odd.matches(formattedMessage)</expression>
- </evaluator>
- <OnMismatch>NEUTRAL</OnMismatch>
- <OnMatch>DENY</OnMatch>
- </filter>
- <encoder>
- <pattern>%-4relative [%thread] %-5level %logger - %msg%n</pattern>
- </encoder>
- </appender>
-
- <root level="DEBUG">
- <appender-ref ref="STDOUT" />
- </root>
- </configuration>
其他Filter不太常用我這里就不講了,大家可以參見官網(wǎng)。
|