我应该使用什么过滤器来定义要使用附加程序记录的特定级别?例如:
java:
LOGGER.debug("Debug message");
LOGGER.info("Info message");
LOGGER.warn("Warn message");
LOGGER.error("Error message");
LOGGER.fatal("Fatal message");
log4j2.xml:
<Configuration>
<Appenders>
<Console name="info-stdout-message">
<PatternLayout pattern="[%logger{36}] %message %n" />
<ThresholdFilter level="info"/>
</Console>
<Console name="detailed-stdout-message">
<PatternLayout pattern="[%logger{36}] [%level] %message %n" />
</Console>
<File name="file-appender" fileName="logs/debug.log">
<PatternLayout pattern="%d{HH:mm:ss dd.mm} [%t] [%-5level] %logger{36} - %msg %n" />
</File>
</Appenders>
<Loggers>
<Root level="debug">
<AppenderRef ref="file-appender" level="debug" />
<AppenderRef ref="info-stdout-message" level="info"/>
<AppenderRef ref="detailed-stdout-message" level="info"/>
</Root>
</Loggers>
</Configuration>
文件输出很好,但在控制台我有这样的结果:
[application.Main] [INFO] Info message
[application.Main] Info message
[application.Main] [WARN] Warn message
[application.Main] Warn message
[application.Main] [ERROR] Error message
[application.Main] Error message
[application.Main] [FATAL] Fatal message
[application.Main] Fatal message
我需要
info-stdout-message
附加器仅输出 INFO 消息,而 detailed-stdout-message
则输出所有 除了 INFO 消息。因此,控制台输出应如下所示:
[application.Main] Info message
[application.Main] [WARN] Warn message
[application.Main] [ERROR] Error message
[application.Main] [FATAL] Fatal message
我不知道如何防止过滤器尊重级别继承。可以这样做吗?
这里有两个控制台附加程序。一种将所有跟踪、调试和信息级别记录到 std_out,另一种将所有警告、错误和致命级别记录到 std_err。这非常有用,例如在 Eclipse 中,因为 std_err 显示为红色。
<Console name="STDOUT" target="SYSTEM_OUT">
<PatternLayout pattern="%d{HH:mm:ss.SSS} (%6r) %-5p [%-7t] %F:%L %x - %m%n" />
<Filters>
<ThresholdFilter level="warn" onMatch="DENY" onMismatch="ACCEPT" />
</Filters>
</Console>
<Console name="STDERR" target="SYSTEM_ERR">
<PatternLayout pattern="%d{HH:mm:ss.SSS} (%6r) %-5p [%-7t] %F:%L %x - %m%n" />
<Filters>
<ThresholdFilter level="WARN" onMatch="ACCEPT" />
</Filters>
</Console>
这有效:
<Console name="info-stdout-message">
<PatternLayout pattern="[%logger{36}] %message %n" />
<Filters>
<!-- Now deny warn, error and fatal messages -->
<ThresholdFilter level="warn" onMatch="DENY" onMismatch="NEUTRAL"/>
<!-- This filter accepts info, warn, error, fatal and denies debug/trace -->
<ThresholdFilter level="info" onMatch="ACCEPT" onMismatch="DENY"/>
</Filters>
</Console>
我花了很长时间才弄清楚如何通过 log4j2.xml 配置文件过滤一系列日志级别。
最终这对我有用:
<Filters>
<ThresholdFilter level="trace" />
<ThresholdFilter level="info" onMatch="DENY" onMismatch="NEUTRAL" />
</Filters>
在这种情况下,Log4J 将记录从 Level.TRACE 到 Level.DEBUG 的所有消息,低于 Level.DEBUG 的所有级别都将被忽略。
实际上,从您的问题来看,您似乎不需要两个不同的附加程序,而是在不同情况下使用两种不同的模式。为此,您应该只使用 PatternSelector。
<Console name="stdout-message">
<ScriptPatternSelector defaultPattern="[%logger{36}] [%level] %message %n">
<Script name="BeanShellSelector" language="bsh"><![CDATA[
if (logEvent.getLevel() == Level.INFO) {
return "INFO";
} else {
return null;
}]]>
</Script>
<PatternMatch key="INFO" pattern="[%logger{36}] %message %n"/>
</ScriptPatternSelector>
</Console>
请检查所有 log4j2 过滤可能性 https://logging.apache.org/log4j/2.0/manual/filters.html
示例配置片段
...
<Console name="DEFAULT" target="SYSTEM_OUT">
<PatternLayout>
<Pattern>[%d][%p][%c:%L:%M] - %m%n</Pattern>
</PatternLayout>
<Filters>
<RegexFilter regex="(?s).*(sql01|sql02|sql03).*" onMatch="DENY" onMismatch="NEUTRAL"/>
</Filters>
</Console>
...
虽然所有这些解决方法在 2014 年都是必要的,但当问题发布时:
在版本2.4中引入了
LevelRangeFilter
(参见LOG4J2-1106),它允许写入:
<LevelRangeFilter minLevel="INFO" maxLevel="INFO"/>
仅选择
INFO
消息或:
<LevelRangeFilter minLevel="WARN" maxLevel="INFO"/>
选择一个范围(从最高到最低特定级别)。
版本2.13.0看到了
LevelMatchFilter
的出现,进一步简化了配置:
<LevelMatchFilter level="INFO"/>
这里是 Log4j2 配置,仅忽略 docxj4 的“警告”日志。查看下面的代码。预先感谢。
<configuration>
<conversionRule conversionWord="coloredLevel" converterClass="play.api.libs.logback.ColoredLevel"/>
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<level>WARN</level>
<onMatch>DENY</onMatch>
<onMismatch>NEUTRAL</onMismatch>
</filter>
<encoder>
<pattern>%date %coloredLevel %logger{15} - %message%n%xException{10}</pattern>
</encoder>
</appender>
<appender name="FILE" class="ch.qos.logback.core.FileAppender">
<filter class="ch.qos.logback.classic.filter.LevelFilter">
<level>WARN</level>
<onMatch>DENY</onMatch>
<onMismatch>NEUTRAL</onMismatch>
</filter>
<file>${application.home:-.}/logs/application.log</file>
<encoder>
<pattern>%date [%level] from %logger in %thread - %message%n%xException</pattern>
</encoder>
</appender>
<logger name="org.docx4j" level="INFO"/>
<root level="INFO">
<appender-ref ref="STDOUT"/>
<appender-ref ref="FILE"/>
</root>
</configuration>