43

我想将 Info Level 及以上级别发送到 XML appender,并将 Error/Fatal Level 发送到 EventLog appender。

我收集到我需要修改配置的根元素,但我在语法上苦苦挣扎。将日志定向到给定级别或级别范围的正确附加程序的配置语法是什么?

这是目前的配置:

<log4net>
  <appender name="SomeXmlAppender" type="log4net.Appender.RollingFileAppender">
    ...
  </appender>
  <appender name="SomeEventLogAppender" type="log4net.Appender.EventLogAppender">
    ...
  </appender>
  <root>
    <level value="DEBUG" />
    <appender-ref ref="SomeXmlAppender" />
    <appender-ref ref="SomeEventLogAppender" />
  </root>
</log4net>

编辑:谢谢@agileguy。那篇文章确实包含我需要的语法。工作解决方案现在如下所示:

<log4net>
  <appender name="SomeXmlAppender" type="log4net.Appender.RollingFileAppender">
    ...
    <evaluator type="log4net.Core.LevelEvaluator">
      <threshold value="INFO"/>
    </evaluator>
    <filter type="log4net.Filter.LevelRangeFilter">
      <levelMin value="INFO" />
      <acceptOnMatch value="true" />
    </filter>
    <filter type="log4net.Filter.DenyAllFilter" />
  </appender>
  <appender name="SomeEventLogAppender" type="log4net.Appender.EventLogAppender">
    ...
    <evaluator type="log4net.Core.LevelEvaluator">
      <threshold value="ERROR"/>
    </evaluator>
    <filter type="log4net.Filter.LevelRangeFilter">
      <levelMin value="ERROR" />
      <acceptOnMatch value="true" />
    </filter>
    <filter type="log4net.Filter.DenyAllFilter" />
  </appender>
  <root>
    <level value="DEBUG" />
    <appender-ref ref="SomeXmlAppender" />
    <appender-ref ref="SomeEventLogAppender" />
  </root>
</log4net>
4

3 回答 3

15

这可以使用appender中的thresholdor元素来完成。filter

请注意,阈值可以直接位于附加器下方,它充当包含过滤器,或者位于evaluator例如

<evaluator type="log4net.Core.LevelEvaluator">
  <threshold value="ERROR"/>
</evaluator>

在适用的情况下,它充当用于跳过缓冲(立即输出)的包容性过滤器。



完整解释(来源):

<threshold value="ERROR" />

阈值在 中实现AppenderSkeleton,因此几乎所有附加程序都支持。这只是一个简单的测试,用于忽略级别低于阈值的日志记录事件。尽早检查阈值,作为一个简单的测试非常有效。

还有另一种方法可以使用过滤器指定与阈值相同的行为。过滤器更加灵活,并且由于它们是可插拔的,您还可以开发自己的自定义逻辑并将其插入过滤器链中。

<filter type="log4net.Filter.LevelRangeFilter">
    <levelMin value="ERROR" />
    <levelMax value="OFF" />
</filter>

与阈值检查一样,过滤器在 AppenderSkelton 基类中实现,几乎所有附加程序都支持。上述过滤器的效果与<threshold value="ERROR" />. 它是一个 LevelRangeFilter,它允许任何级别在ERRORto OFF(包括)范围内的事件。注意OFF是最高层的名字,反之ALL是最低层的名字。

过滤器具有很大的灵活性,因为可以将多个过滤器链接在一起以提供对输出事件的细粒度控制。正因为如此,它们在性能方面也有更高的成本,链中的每个过滤器都是一个对象,并被要求决定正确的行动方案。在阈值过滤的简单情况下,应优先使用阈值属性而不是过滤器。

Evaluator实现,BufferingAppenderSkeleton因此仅由扩展此基类并提供缓冲支持的附加程序支持。SmtpAppender 就是这样一种附加程序。

Evaluator是一个可插入对象,BufferingAppenderSkeleton 使用它来确定是否不应缓冲日志记录事件,而是立即写入/发送。如果 Evaluator 确定事件很重要,则当前缓冲区的全部内容将与事件一起发送。评估器不像阈值或过滤器那样起作用,因为它不丢弃事件。

于 2014-06-02T17:17:03.677 回答
6

您可以为每个附加程序设置不同的阈值属性。appender 会忽略所有级别低于阈值级别的日志事件。我在下面粘贴了两个附加程序,一个用于文件,另一个用于数据库(您应该设置连接字符串)。数据库附加程序有一个阈值属性,指示只有错误将保存在数据库中。

<configuration>
  <log4net>
    <!--Database appender-->
    <appender name="DbAppender" type="log4net.Appender.ADONetAppender">
      <bufferSize value="0" />
      <connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
      <connectionString value="Data Source=AEG-PC\SQLEXPRESS;Initial Catalog=JCZ6;Uid=sa;Pwd=qwerty;" />
      <commandText value="INSERT INTO Log4Net ([date],[thread],[level],[logger],[message],[exception]) VALUES 
         (@log_date, @thread, @log_level, @logger, @message, @exception)" />
      <parameter>
        <parameterName value="@log_date" />
        <dbType value="DateTime" />
        <layout type="log4net.Layout.RawTimeStampLayout" />
      </parameter>
      <parameter>
        <parameterName value="@thread" />
        <dbType value="String" />
        <size value="255" />
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%t" />
        </layout>
      </parameter>
      <parameter>
        <parameterName value="@log_level" />
        <dbType value="String" />
        <size value="10" />
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%p" />
        </layout>
      </parameter>
      <parameter>
        <parameterName value="@logger" />
        <dbType value="String" />
        <size value="255" />
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%c" />
        </layout>
      </parameter>
      <parameter>
        <parameterName value="@message" />
        <dbType value="String" />
        <size value="4000" />
        <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%m" />
        </layout>
      </parameter>
      <parameter>
        <parameterName value="@exception" />
        <dbType value="String" />
        <size value="4000" />
        <layout type="log4net.Layout.ExceptionLayout" />
      </parameter>
      <threshold value="Error" /> <!--THIS IS THE IMPORTANT LINE-->
    </appender>
    <!--File appender-->
    <appender name="FileAppender" type="log4net.Appender.FileAppender">
      <file value="log-file.txt" />
      <appendToFile value="true" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
      </layout>
    </appender>
    <root>
      <level value="INFO" />
      <appender-ref ref="FileAppender" />
      <appender-ref ref="DbAppender" />
    </root>
  </log4net>
</configuration>
于 2014-05-22T13:53:00.737 回答
2

我有同样的问题。看起来,假设我理解原始问题,阈值将不起作用,因为它将某些输出发送到一个附加器,并将其余的输出到另一个附加器。如上所述,我能够使用 LevelRangeFilter 让它工作。我希望 ERROR、INFO 和 WARN 转到一个附加程序,而所有其他附加程序转到另一个附加程序,但不是 ERROR、INFO 和 WARN。

这是对我有用的配置:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <configSections>
        <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
    </configSections>
    <log4net>
        <appender name="LoggingAppender" type="log4net.Appender.FileAppender" >
            <file value="logs.txt" />
            <filter type="log4net.Filter.LevelRangeFilter">
                <levelMin value="INFO"/>
                <levelMax value="OFF"/>
            </filter>
            <layout type="log4net.Layout.PatternLayout">
                <conversionPattern value="%date [%thread] %-5level %logger [%ndc] - %message%newline" />
            </layout>
        </appender>
        <appender name="TracingAppender" type="log4net.Appender.FileAppender" >
            <file value="traces.txt" />
            <filter type="log4net.Filter.LevelRangeFilter">
                <levelMin value="ALL"/>
                <levelMax value="DEBUG"/>
            </filter>
            <layout type="log4net.Layout.PatternLayout">
                <conversionPattern value="%date [%thread] %-5level %logger [%ndc] - %message%newline" />
            </layout>
        </appender>
        <root>
            <appender-ref ref="LoggingAppender"/>
            <appender-ref ref="TracingAppender"/>
        </root>
    </log4net>
</configuration>

谢谢,尼克

于 2015-07-06T02:36:04.280 回答