Logback 和不同级别
Logback and different levels
有 3 个附加程序:STDOUT、FILE-AUDIT 和 FILE-ERROR。如何将所有消息记录到 STDOUT 和 FILE_AUDIT(包括错误),但错误消息在 FILE-ERROR 中重复。我的一部分 logback.xml:
<logger level="all"
additivity="true">
<appender-ref ref="FILE-AUDIT" />
<appender-ref ref="STDOUT" />
</logger>
<root level="error">
<appender-ref ref="FILE-ERROR" />
</root>
你应该用 ThresholdFilter
:
定义你的 FILE-ERROR
appender
<appender name="FILE_ERROR" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>[...]</file>
<!-- [...] -->
<filter class="ch.qos.logback.classic.filter.ThresholdFilter">
<level>ERROR</level>
</filter>
</appender>
然后,只需将所有附加程序添加到根记录器即可:
<root level="INFO">
<appender-ref ref="STDOUT" />
<appender-ref ref="FILE-AUDIT" />
<appender-ref ref="FILE-ERROR" />
</root>
这样,STDOUT
和 FILE-AUDIT
包含所有消息,但 FILE-ERROR
只包含错误消息。
有 3 个附加程序:STDOUT、FILE-AUDIT 和 FILE-ERROR。如何将所有消息记录到 STDOUT 和 FILE_AUDIT(包括错误),但错误消息在 FILE-ERROR 中重复。我的一部分 logback.xml:
<logger level="all"
additivity="true">
<appender-ref ref="FILE-AUDIT" />
<appender-ref ref="STDOUT" />
</logger>
<root level="error">
<appender-ref ref="FILE-ERROR" />
</root>
你应该用 ThresholdFilter
:
FILE-ERROR
appender
<appender name="FILE_ERROR" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>[...]</file>
<!-- [...] -->
<filter class="ch.qos.logback.classic.filter.ThresholdFilter">
<level>ERROR</level>
</filter>
</appender>
然后,只需将所有附加程序添加到根记录器即可:
<root level="INFO">
<appender-ref ref="STDOUT" />
<appender-ref ref="FILE-AUDIT" />
<appender-ref ref="FILE-ERROR" />
</root>
这样,STDOUT
和 FILE-AUDIT
包含所有消息,但 FILE-ERROR
只包含错误消息。