很多时候,我想从特定的聊天记录器中排除日志记录到某个级别。不幸的是,以下第一条规则对于该记录器的所有级别都是最终规则,因此第二条规则(这只是我的默认规则)不会从中记录任何内容:
<logger name="ChattyLogger" maxlevel="Warn" writeTo="blackhole" final="true" />
<logger name="*" minlevel="Info" writeTo="default" />
一种可能性是使用过滤器:
<logger name="ChattyLogger" writeTo="blackhole">
<filters>
<when condition="level<=LogLevel.Warn" action="IgnoreFinal" />
</filters>
</logger>
<logger name="*" minlevel="Info" writeTo="default" />
但是语法很丑,尤其是长度和需要转义条件表达式。
由于这似乎是一个常见的要求,我想知道我是否忽略了一些东西。
我在 Silverlight 下使用 nlog,但我认为这无关紧要。