15

很多时候,我想从特定的聊天记录器中排除日志记录到某个级别。不幸的是,以下第一条规则对于该记录器的所有级别都是最终规则,因此第二条规则(这只是我的默认规则)不会从中记录任何内容:

<logger name="ChattyLogger" maxlevel="Warn" writeTo="blackhole" final="true" />

<logger name="*" minlevel="Info" writeTo="default" />

一种可能性是使用过滤器:

<logger name="ChattyLogger" writeTo="blackhole">
  <filters>
    <when condition="level&lt;=LogLevel.Warn" action="IgnoreFinal" />
  </filters>
</logger>

<logger name="*" minlevel="Info" writeTo="default" />

但是语法很丑,尤其是长度和需要转义条件表达式。

由于这似乎是一个常见的要求,我想知道我是否忽略了一些东西。

我在 Silverlight 下使用 nlog,但我认为这无关紧要。

4

1 回答 1

12

试试这个:

<logger name="ChattyLogger" maxlevel="Warn"/>
<logger name="ChattyLogger" minlevel="Error" final="true" writeTo="default"/>
<logger name="*" minlevel="Info" writeTo="default" />
于 2013-06-04T21:22:56.977 回答